expository Remarks About 


The Development of the Rigid Disk Drive(s) to Host(s) Interface 


Development of the rigid disk drive standard began in mid 1979 at 
the urging of several drive manufacturers. At that time, there 
were no defacto interfaces nor was there a significant number of 


drives in the field. 


Public announcements. were made and letters were sent out to disk 
drive/host manufacturers and users to form a substantial 
membership body to write the standard. The participants on the 
committee were drawn from many sectors of the industry: drive 
manufacturers, host manufacturers, government, users and systems 
houses. The observers, whose number approached 156, received a 
full mailing after each meeting and some even participated in the 
working discussions via mail presentations. 


The standard was drafted in a relativly short time due to the 
clear objectives, force of the market and the strong commitment 


of the large active membership. The group not only met for the 
usual bimonthly meetings but’ added working meetings in between. 


The resultant interface standard is an original design by the 
committee based Upon proven techniques. The standard was 
developed with a minimum mandatory set of requirments for low 
cost. It also includes a well defined, but optional, set of 
extensions for future drives and current drives with enhanced 


features. 


While work was in progress, a 5 1/4 inch rigid disk drive was 
announced, and the committee decided to drop the word 8 inch from 
the title because they believed that this new standard was ideal 
for all size rigid disk drives. 


The document was approved by the technical committee, X3T9.3, in 
October 198g. At that time, about six manufactures of drives and 
hosts had announced that they intended to use the interface as 


their standard. 


The trade press has done an excellent job of keeping the industry 
informed about the committee and its work. It has also been 
helpful in encouraging a professional interest in the committee's 
work thus facilitating the progress of the development of the 


standard. 
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ABSTRACT: 


Strict mechanical, electrical, and functional specifications are 
defined for attaching disk drive(s) to their host(s). Certain 
capabilities are defined as extensions. This interface will 
facilitate the interconnection of disk drive(s) to the host(s) and 
thus provide a common interface specification for both. 
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(This foreword is not part of American National Standard for 
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This standard was developed to specify a common interface 
definition and to enumerate common optional features and specify 
connector pin assignments and functional protocols of these 
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1.8 Scope 


This standard applies to rigid disk drive(s) and defines the 
necessary functional and electrical requirements (including logic 
Signals) and the mechanical requirements of the interface for 
connection of conforming rigid disk drive(s) to host system(s). 
This standard is distinct from a specification in that it 
delineates a minimum set of requirements consistent with 
compatibility and interchangeability at the interface level. 


This standard will facilitate the interconnection of rigid disk 
drive(s) to host system(s) by a user that has available the 
technical capabilities to verify and test performance up through 
the functional level. The user should have the capability to 
specify the overall system hardware and software that will be 
unique for a particular device and host combination. 


This standard by itself does not guarantee plug compatibility of 
devices meeting this standard. To obtain total interchangeability 
of devices an operational specification must be defined. Neither 
the operating specification nor the power requirements are defined 
by this standard. 


This standard was developed for the 8 inch rigid disk drive but 
its use is not limited to 8 inch rigid disk drives. 


This standard does not apply where no clear separation exists 
between the device and the host. 


This standard does not prescribe the magnetic encoding or decoding 
method, the recording techniques, nor the format used to write or 
read data but allows the reporting of all of the above. Unique 
characteristics offered by a vendor are allowed where specified in 


the standard. 
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The design 
1. 
2. 
3. 


9. 


10. 


X3T9/1226, 


of this interface provides the following features: 
Addressability of up to 8 devices. 
Capability for both variable and fixed sector sizes. 


Transfer data across the interface at up to 18 megabits 
per second. 


Daisy chain configuration utilizing a 59 wire flat 
ribbon cable. 


Supports a radial attention and selection capability 
through the daisy chain bus. 


Permits self configuration of the system and self 
definition of the individual devices. 


Extensive error reporting and status information is 
provided. 


This standard is intended for low cost implementations 
and offers a high degree of flexibility. 


This interface is designed to be capable of enhancement 
beyond the current range of known devices. 


The command set has been divided into mandatory and 


optional functions to allow for different levels of 
implementation. 
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1.1 Definitions 

1.1.1 State Nomenclature. 
The nomenclature used to define voltage levels and 
signal states on the interface and used to define 


logical states internally to the device and their 
correlation is defined in Table 1-1. ; 


Table 1-1 


State Nomenclature 


Interface | | Internal 
Voltage Level | Signal | Logical State | Logical 
| | | 
Aan nn nena | State | 4-2 -~-| Transition 
| | | 
Single | Differential | | Tables | Text | 
Ended | | | | 
| | | | | 
| | l | | 
"Low" | + line > | Active | 1 | one |JSET = X to one 
| - line | | | | 
| l | | | 
| | | | | 
| | | | | 
"HIGH" | -= line > | Inactive | ) | zero |RESET =X to zero 
| + line | | | | 
| | | | 
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1.1.2 Mandatory 


These functions must be included in all. devices 
and hosts. They must be implemented as defined in 
this specification. 


1.1.3 Optional 


These. features may be implemented in the host 
and/or device as defined in this specification. If 
the feature is included but the implementation can 
not be exactly the same as defined in this 
specification than the feature must be included in 
the Vendor Unique area. 


1.1.4 Vendor Unique 


These features may be defined by each vendor as 
required. Caution should be exercised in defining 
and using these features since they are not 
standard between vendors nor have they been 
endorsed by ANSI. 
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2.@ Physical Characteristics 


Unless otherwise indicated, all values are specified with a plus 
or minus five percent tolerance. 


2.1 Cabling Configuration 


The devices shall be connected to a host by means of a 56 
conductor flat ribbon or equivalent cable. Three meters (3 Mm) 
shall be the maximum length of the interface cable. Note that the 
cumulative length of the cable in a daisy chain string shall not 
exceed three meters. See Figure 2-l. 


Delivery of primary power (AC and/or DC) shall not be accomplished 
on the interface cable. A separate DC common (ground) may be 
provided. Specifications for power supply cabling and grounding 
requirements are not a subject of this standard. Refer to vendor 


specifications for power/ground information. 


2.2 Connector Specification 


The connector type shall be the 56 pin two row, inline flat ribbon 
rectangular connector illustrated in Figure 2-2 and 2-3 with 
dimensicns specified in Table 2-1 and 2-2. 


Pin assignments and signal nomenclature are illustrated in Table 
2-3. Termination of the individual cable lines shall be at the 
host and at the last ‘device according to the electrical 
requirements of Section 2.4. 


The cable plug (Figure 2-2) shall be polarized and polarization 
shall be done with a.center top tab. 


2.3 Cable Characteristics 


The flat ribbon or equivalent cable shall consist of 58 conductors 
of 28 AWG. The characteristic impedance of the lines shall be 168 
ohms plus or minus 19%. Conductor spacing shall be 1.27 
millimeters (@.85@ inch) center to center to provide for 
mechanical termination. Additionally, the flat ribbon cable shall 
be marked in such a way as to identify line number one (pin 1). 


If the cable contains a shield ground it shall be connected to pin 
number one of the interface connector. 
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Figure 2-1 
Interface Configuration 
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Table 2-1 


Dimensions of Interface Cable Plug (see Figure 2-2) 


Millimeters Inches 
cl 2.54 @.16 
C2 68.95 ; 2.4 
C3 2.54 6.1869 
C4 8.357 @.329 
c5 3.30625 @.130 
C6 68.872 2.586 
C7 6.0996 0.248 
C8 8.153 9.321 
c9 13.487 0.531 
on’ 3.81 8.159 
Cil 1.27 0.056 
C12 6.996 6.240 
C13 32.385 1.275 
C14 3.362 6.130 
C15 7.493. 6.295 
C16 2.567 0.165 
C17 1.625 @.664 


Note 1: 58 Contacts on 1.27 mm (6.959 in) 
staggered spacing = 62.23 mm (2.459 in) 


Note 2: Tolerances +/- 9.127 mm (.605 in) noncumulative 


Table 2-2 


Dimensions of Interface Cable Receptacle (see Figure 2-3) 


Millimeters Inches 

2.54 6.108 
D2 . 82.86 3.268 
D3 2.54 . 0.198 
D4 4.83 9.198 
DS 8.51 6.335 
D6 _ 72.64 2.868 
D7 78.74 3.196 
D8 13.94 @.549 
D9 4.19 6.165 
D1O 6.09 @.240 
Dll 6.608 0.260 


Note 1: 58 Contacts on 2.54 mm (8.199 in) 
Spacing = 60.96 mm (2.48 in) 


Note 2: Tolerances +/= 6.127 mm (.6@5 in) noncumulative 
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Figure 2-2 


Interface Cable Plug 
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2.4 Electrical Characteristics 
2.4.1 Bidirectional Control Bus Lines 


The bidirectional Control Bus is used in two different modes: 


Daisy Chain Mode and Radial Mode. 


In the Daisy Chain Mode eight bits of information and an optional 
parity bit shall be transferred between the host and the selected 


device, 


In Radial Mode each of the eight Control Bus lines shall be used 
separately for communication with one specific device. In this 
way, one bit of information is transferred to or from all devices 
simultaneously. Each device shall have provisions (jumper, 
switches, etc) to connect the radial line to any one of the eight 
Control Bus lines. The optional Control Bus Parity Bit shall not 
be used in the Radial Mode. The configuration of the bidirectional 


Control Bus lines is shown in Figure 2-4. 
2.4.1.1 Control Bus Drivers 


The bus drivers for the parallel information shall be either 
three-state or open collector. The driver for the radial signal in 


the device shall be open collector. 


All bus driver outputs for "LOW" level shall sink 24 milliamps 
minimum. The "LOW" level output voltage shall be 9.5 volt maximum, 
“Driver outputs for "HIGH" level shall have a "HIGH" level output 
voltage of 2.4 volts minimum, 5.25 volts maximum. A 16 milliamps 
source current is Prova oe by the 470 ohms terminator discussed in 


Section 2.4.1.3. 


The leakage current in the high upeaanet state ("OFF" state for 
open collector drivers) shall not exceed 8.25 milliamp for either 
"HIGH" or "LOW" level on the Control Bus. 


The total number of drivers connected to any Control Bus line 
shall not exceed ten (one in the host, one in each of the eight 
devices for the parallel lines, and one in a single device for the 
radial line). 


2.4.1.2 Control Bus Receivers 


The maximum "LOW" level input current shall be -486 microamps. The 
maximum "HIGH" level input current shall be 8@ microamps. The 
maximum "LOW" level input voltage shall be 9.9 volt. The minimum 


"HIGH" level input voltage shall be 2.9 volts. 


The total number of receivers connected to any Control Bus line 
shall not exceed ten (one in the host, one in each of the eight 
devices for the parallel lines, and one in a single device for the 
radial line). 
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Figure 2-4 


Cable Configuration for Bidirectional Control Bus Signals 
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2.4.1.3 Control Bus Termination 


A 478 ohms resistor, plus or minus 16% shall be installed at the 
host end of all Control Bus lines (Control Bus Bits 6-7 and 
Control Bus Parity) connected to +5 volts, plus or minus 5%. See 
Figure 2-4. : 


2.4.2 Single Ended Lines 


The cable configuration of the single ended lines shall be as 
shown in Figures 2-5 to 2-7. 


2.4.2.1 Single Ended Line Drivers 


The drivers shall have open collector outputs capable of sinking 
46 milliamps at "LOW" levels. "LOW" level output voltage shall 
not exceed 9.4 volt. The high level leakage current shall not 


exceed 259 microamps. 


2.4.2.2 Single Ended Line Receivers 


The receivers shall accept TTL logic levels. For noise immunity 
the receivers shall have an input hysteresis of 6.4 volt 
minimum, with a positive going threshold voltage between 1.4 and 
2.8 volts and a negative going threshold voltage between 6.5 and 
1.1 volts. "Low" level input current shall ‘be -1.2 milliamps 
or less. The "HIGH" level input current shall be 46 microamps 


maximum, 


2.4.2.3 Single Ended Line Termination 


All single ended lines originating at the host shall be terminated 
at the last device with 338 ohms, plus or minus 5%, to ground 
and 226 ohms, plus or minus 5%, to +5 volts. All single ended 
lines originating at the devices shall be terminated in the same 


way at the host. 


2.4.2.4 Port Enable Termination 

A 16 kilohms plus or minus 19% pullup resistor to +5 volts shall 
be added to the Port Enable line in each device to generate an 
inactive signal state whenever the device is not connected (see 


Figure 2-6). 
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Figure 2-5 


Cable Configuration for Unidirectional Single Ended Lines from Host 
(except Port Enable) 


es IN +5V 
| 1\ To Device | IN To Device 
--|  >----- x a-|[  d2---- x , | 
11/7 Logic | | | 7 Logic 
1 I/ 1 |/ \ 
IN | | | | / 228 
From | \ | | \ Ohms 
Xeeee| > a------------ 9 ttt tt teen nae etter tse “. 
Host | / | | | 
Logic |/ | 
| | / 
\ 338 
| | / Ohms 
| 
GND 
Host } all but Last Device | Last or only Device 
(if multiple devices) : 
Figure 2-6 
Cable Configuration for Port Enable 
* +5V | *  +5V 
| | 
| \ | \ 
/ 16k Ohms / 16k Ohms 
| s om | \ 
| | 
| | | | 
1 IN 1 IN +5V 
| | | \ To Device | | | \ To Device . 
at] Daen-- x etl] >ee--- x | 
| | | / Logic | 1 | / Logic | 
1 {7 1 I/ \ 
IN | | ] | / 226 
From | \ | | \ Ohms 
Xeree | tee ane nnn 9 tt nnn mn a eee -. 
Host | / l | | 
Logic |/ | 
| | / 
\ 336 
| | / ohms 
| 
GND 
Host | all but Last Device ] Last or only Device 
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Figure 2-7 
Cable Configurations for Unidirectional Single Ended Lines from Devices 


| | * 4+5V 
| 
Open | Open | | 
Collector Collector \ 
From #2---— | From  s+-+--- | IN / 228 
Device| ye Device -| \ | \ To \ Ohms 
Logic-| }--- | Logic, | Jann-- | aaeal >a--x / 
pea / | =| / | | | / Host Logic | 
re 1 | ]  oAeaaR= 1 J os 1/ | 
x | x Enable | | | 
Enable = meta n nna ene en nnnn {Ase e- aa ad aa a a ar aa “. 
| 
| | \ 
/ 330 
| | \ Ohms 
| 
| | I 
| | GND 
Last or only Device] all but the Last Device] Host 
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2.4.3 Differential Lines 


The differential line drivers and receivers shall operate from a 
single + 5 volts supply. They shall operate to 18 MHz and shall 
be capable of meeting the timing requirements of Sections 5.3 
and 5.4 while operating the recommended terminated 


cable configuration, 


The cable configuration of the differential lines shall be as 
shown in Figures 2-8 and 2-9. 


An active signal state is defined as the "+" line being equal or 
more positive than the "={""_line. An inactive signal state 15S 
defined as the "=" line being more positive than the "+" line. 


2.4.3.1 Differential Line Drivers 


The differential line drivers shall have a three-state output and 
be capable of sinking or. sourcing a minimum of 29 milliamps in 
the active state. In the inactive or high impedance state, 
leakage current shall not exceed plus or minus 29 microamps. 


2.4.3.2 Differential Line Receivers 


The common mode input range capability of the receivers shall be 
at least +7 to -7 volt. The differential input voltage shall .be 
-9.2 volt minimum and +@6.2 volts maximum. The input hysteresis 
should be 149 (+/-= 78) millivolts minimum. 


2.4.3.3 Differential Line Termination 


Each line of all pairs’ of differential lines shall be 
terminated with 199 ohms, plus or minus 16%, to ground both at 
the host and the last device. 
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Figure 2-8 


Cable Configuration for Differential Lines from Host 


IN | IN | IN 
From [{ \------ ~ tenn I \ To Device -=-#<-=<-=< | \ To Device 
x----=] > Paty ol | >a------ x | | | >--------x 
Host | /---- | | ---| / Logic | a--| / Logic 
Logic |/ 1 ft | | ] 1 Is 
1 | | | | | 
1 ot 4 | | "+" Line | | 
wananennn- Fae tn a tt te ee a pe een 
| | | | "." Line | | | 
| aan, tenn ott tt tt nnn nen .tt---- | 
| | | | | | 
\ \ \ \ 
/ 196 / 108 | | 1108 / 186 
\ Ohms\ Ohms \ ohms \ Ohms 
/ / | | / / 
| | | | 
~~ = | | a = 
GND GND GND GND 
| | 
Host | All but Last Device | Last or only Device 
(if multiple devices) 
Figure 2-9 
Cable Configuration for Differential Lines from Device 
From “IN | From - IN | IN 
Xeeeeen |] \e------ Xen ] \eacceen a te =| \ To Host 
Device | > | |. Device } > | | | >aeaan--- x 
Logic -| /=--= | Logic =| /-=--- | | ---| / Logic 
IZ | 1 | 117 | 1 | | | IZ 
x | | Enable x-- | | | | 
Enable | 1 1 "+" Line | | | | 
Se eaentanteeeteaaetee fae ete en ef ne ne tn nen 
| | | "=""Line | | | | 
| Sues sueseaeeee Soa ake eon eee  asasss | 
| | | | | | 
\ \ \ 
/ 108 / 199 | | / 100 / 166 
\ Ohms\ Ohms \ Ohms \ Ohms 
/ Fo: | | / ie 
| | | | 
Se a | | a a 
GND GND GND GND 
| | 
Last or only Jall but the Last Device | Host 
Device (if multiple devices) 
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Table 2-3 


Pin Assignment 


Signal Ground 


Pin Pin Signal Name Signal Source 
1 Ground © aa 

Control Bus 
2 16 Bit @, Select/Attn.Device @ Host/Device 
3 18 Bit 1, Select/Attn.Device 1 Host/Device 
4 1é Bit 2, Select/Attn.Device 2 ‘Host/Device 
5. 19 Bit 3, Select/Attn.Device 3 Host/Device 
6. 16 Bit 4, Select/Attn.Device 4 Host/Device 
7: 18 Bit 5, Select/Attn.Device 5 Host/Device 
8 18 Bit 6, Select/Attn.Device 5 Host/Device 
9. 19 Bit 7, Select/Attn. Device 7 Host/Device 
11 12 Parity (optional) Host/Device 
13 14 Select Out/Attn. In Strobe Host 
15 16 Command Request Host 
17 18 Parameter Request Host 
19 28 Bus Direction Out Host 
21 22 Port Enable Host 
23 24 Address Mark Control (optional) Host 
25 26 Read Gate Host 
27 28 Write Gate Host 
29 39 Bus Acknowledge Device 
31 32 Index Device 
33 34 Sector/Address Mark Detected Device 
35 36 Attention Device 
37 36 Busy Device 
39 38 Read Data + Device 
49 38 Read Data - Device 
42 4l Read/Reference Clock + Device 
43 41 Read/Reference Clock - Device 
45 44 Write Clock + Host 
46 44 Write Clock - Host 
48 47 Write Data + Host 
49 47 Write Data - Host 


58 Ground bah 
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3.8 Signal Definitions 


This section provides signal definitions and their intended 
operation and/or status. Relative signal timing and tolerance is 
defined in Section S. 


Note: The timing diagrams of Section 5 shall take precedence over 
all other timing definitions. 


3.1 Control Bus 


The Control Bus shall be used for bidirectional transfer of 
information. The direction of transfer shall be determined by the 


Bus Direction Out signal. 


The electrical characteristics of the Control Bus signals are 
defined in Section 2.4.1. The Control Bus Lines shall be "LOW" for 
an active signal state and shall be "HIGH" for an inactive signal 


state. 


Throughout the specification of this interface the host shall be 
in control of the Control Bus. All communications between the host 
and the selected device shall be determined by the host. 


The Control Bus is used in two modes. When Select Out/Attention In 
Strobe is active, the Control Bus shall be in Radial Mode. When 
the Command Request, Parameter Request, or Bus Acknowledge is 
active, the Control Bus shall be in Daisy Chain Mode. 


3.1.1 Radial Mode 


Each device shall be assigned a unit number 6-7, by radially 
attaching to one Select/Attention device (8-7) line as per Table 


273 eo 
3.1.1.1 Select Out Mode 


When both Bus Direction Out and Select Out/Attention In Strobe are 
active each radial line shall transfer the selection information 


to the corresponding device. 


3.1.1.2 Attention In Mode 


When Bus Direction Out is inactive and Select Out/Attention In 
Strobe is active, each device shall gate its internal Attention 
Condition onto its corresponding Control Bus line. 
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3.1.2 Daisy Chain Mode 


When in the Daisy Chain Mode, all Control Bus transfers shall 
consist of a two byte sequence. The transfer is asynchronous and 
controlled with a handshake protocol. The first byte is 
transferred using a handshake between the Command Request Signal 
and the Bus Acknowledge signal. The second byte is transferred 
using a handshake between the Parameter Request Signal and the Bus 
Acknowledge Signal. Refer to Section 4 for the command 


definitions. 


3.1.2.1 Command Out 


When both the Bus Direction Out and Command Request are active the 
host shall transfer a Command Byte to the selected device. 


When bit 6 in the Command Code (first byte) is one, the second 
byte shall be Parameter Out (see Section 3.1.2.2 and Table 4-1). 


When bit 6 in the Command Code (first byte) is zero, the second 
byte shall be Parameter In (See Section 3.1.2.3 and Table 4-2). 


When the state of the Bus Direction Out Signal for the transfer of 
the parameter (second byte) does not comply with the definition of 
bit 6 of the Command Code, this condition shall set the Attention 
Condition and the Control Bus Error Bit in the General Status Byte 


(see Section 4.4.1.2). 


The condition of the Bus Direction Out Signal being inactive and 
the Command Request Signal being active is a violation of protocol 
and may optionally set the Attention Condition and the Control Bus 
Error Bit in the General Status Byte (see Section 4.4.1.2!. 


3.1.2.2 Parameter Out 

When both Bus Direction Out and Parameter Request are active, the 
host shall transfer a Parameter Byte to the selected device (see 
Table 4-1). , 

3.1.2.3 Parameter In 

When the Bus Direction Out Signal is inactive and the Parameter 


Request signal is active, the host is requesting a Parameter Byte 
(status) to be transferred from the selected device (see Table 


4-2). 
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3.1.3 Control Bus Bits 0-7, Select/Attention Device 0-7 


The eight Control B8us_ signals, 6-7, shall be used _ for 
communication between the host and the device as defined in 
Sections 3.1.1 and 3.1.2. Control Bus Bit § shall be the least 


significant bit. 


3.1.4 Control Bus Parity (optional) 


When the Control Bus is used in Daisy Chain Mode the bidirectional 
Control Bus Parity Bit shall be odd parity (odd number of ones) of 
the eight Control Bus Bits and the Control Bus Parity Bit. 


When the Control Bus is used in the Radial Mode, the Control Bus 
Parity Signal is not used and shall be inactive. 


If Control Bus Parity is implemented in either the host or the 
device but not in both, the Control Bus shall function without an 


error condition. 


3.2 Control Interface 


This group of signals are unidirectional in nature. The electrical 
characteristic of the contol interface lines is defined in Section 
2.4.2. All control interface Lines shall be “LOW" for an active 
signal state and shall be "HIGH" for an inactive signal state. 


3.2.1 Port Enable 


This signal is normally held active by the host. When this signal 
is active all devices attached to the interface shall respond to 
the interface protocol as described by this specification. 


This signal may be used to disable all devices when host power is 
lost and/or as a programmed reset. If the interface cable is being 
disconnected from a device, the device shall be reset by the 
active to inactive. transition on this line. (See Section 4.2.2.3 


for multiported drives). 


When this signal changes from active to inactive all devices shall 
be deselected within 29 milliseconds maximum except for the write 
circuitry in each device which shall be disabled within 1 
microsecond maximum. The device shall remain deselected while Port 
Enable is inactive. 


Upon detecting Port Enable going inactive each device must go to 
its Initial State as defined below (also see the vendor 
specification). After Port Enable changes from inactive to active 
and after the initial state is reached the device shall set the 


Attention Condition, 
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Initial State This is the state a device shall reach 
after being powered up, Port Enable has 
become active or a Selective Reset Command 
has been received. 


The conditions are: 
1. The device shall be deselected 


2. The device shall respond to the Select 
Out/Attention In Strobe Signal. 


3. All parameters of commands with 
Parameters Out in Table 4-1 shall be reset 
to zero (except Spin Control - see Section 


4.1.2.6). 


4. The Device Attribute Table, if 
implemented, shall be set to its initial 
value (see Section 4.3). 


5. All resettable error conditions shall 
be reset. If the cause of the error still 
exists, it shall set the error conditions 
again. 


6. The Initial State bit in Sense Byte 2 
shall be set. 


3.2.2 Bus Direction Out 


The Bus Direction Out Signal is transferred from the host to all 
attached devices. Bus Direction Out controls the direction of 
transfer on the Control Bus. When the Bus Direction Out Signal is 
active this defines a transfer from the host to the device. 


3.2.3 Select Out/Attention In Strobe 


This signal is transferred from the host to all attached devices. 
It has two different functions depending on the state of the Bus 


Direction Out Signal. 


When the Bus Direction Out Signal is active, the signal is Select 
Out Strobe. 


When the Bus Direction Out Signal is inactive, the signal is 
Attention In Strobe. 
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3.2.3.1 Select Out Strobe 


Only one device shall be selected at any one time. When the Bus 
Direction Out Signal is active, the active going edge of the 
Select Out Strobe Signal is used for selecting/ deselecting the 
device. : 


When any Control Bus Signal is active and Select Out Strobe 
transitions to active, the device connected to that specific 
Control Bus line shall become selected. 


When any Control Bus Signal is inactive and Select Out Strobe 
transitions to active, the device connected to that specific 


Control Bus line shall become deselected. 


When all Control Bus Signals are inactive and the Select Out 
Strobe transitions to active, all attached devices shall become 


deselected. 


3.2.3.2 Attention In Strobe 


When the Bus Direction Out Signal is inactive, the Attention In 
Strobe shall be used to gate the device's internal Attention 


Condition (see Section 3.2.8) onto the corresponding Control Bus 
line connected to that device (see Appendix A). 


3.2.4 Command Request 


This signal initiates the handshake control from the host to the 
selected device. The active state of this signal signifies the 
transfer of the first byte of each two-byte transfer. Until the 
receipt of Bus Acknowledge, the Command Request Signal shall 


remain active. 


3.2.5 Parameter Request 


This signal is also a handshake control line from the host to the 
selected device. The active state of this signal for a Parameter 
Out Command indicates that the output Parameter Byte is valid on 
the Control Bus. The active state of this signal for a Parameter 
In Command requests the selected device to place the Parameter 
Byte on the Control Bus. Until the receipt of Bus Acknowledge, 
the Parameter Request Signal shall remain active. 
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3.2.6 Bus Acknowledge 


This signal is returned from the selected device to the host. The 
Bus Acknowledge Signal has two functions. 


When the Control Bus is used in Radial Mode (Select Out/Attention 
In Strobe active), the selected device shall make the Bus 
Acknowledge Signal active to acknowledge its selection. 


When the Control Bus is used in Daisy Chain Mode, the Bus 
Acknowledge Signal performs the asynchronous handshake with the 
Command Request Signal or the Parameter Request Signal. 


3.2.7 Busy 


This signal shall be held active by the selected device if the 
selected device is unable to accept additional commands. The Busy 
Signal shall change to the active state before the active going 
edge of the Bus Acknowledge of a Time Dependent Command (see 
Section 4.9) that causes the device to become busy. The busy 
Condition could occur during power up sequencing, seeking, or 
execution of diagnostics. The Busy Signal shall not be made 
active if the device can accept commands. 


The busy to not busy transition within the device shall set the 
Attention Condition within the device (see Section 3.2.8). 


If Command Request becomes active when the Busy signal is already 
active the device will not respond with Bus Acknowledge before 


the function is completed and Busy is made inactive. 


3.2.8 Attention 


This signal is a party line signal (“wired OR") from all devices 
to the host, independent of the selection of a device. 


The Attention Signal shall be made active by a device, if the 
device's internal Attention Condition is set to one, and if 
Attention is enabled (see Attention Control Command Section 
4.1.1.1). The Attention Condition shall be set if the device 
requires service from the host. The detailed conditions to set 
the Attention Condition are defined in Section 4. 


The Attention Condition of the selected device shall only be 
reset by the Clear Attention Command or the Clear Fault Command. 
Issuing the -Clear Fault Command shall reset only those error 
status bits and the resulting Attention Condition if the error 
condition can be reset. A Clear Attention Command shall reset the 
Attention Condition independent of error conditions. 
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3.2.9 Index 


Index is a signal that indicates to the host that a reference 
point or index area is passing under the heads of the selected 
device. One Index Pulse shall be generated by the selected device 
per revolution of the recording media. 


Whenever the device is ready and the head carriage is not in 
motion, a valid Index Signal shall be transferred from the 
selected device to the host. When the head carriage is in motion 
or the device is not ready the Index Signal may or may not be 
valid (see vendor specification). 


3.2.18 Sector/Address Mark 


The Sector Signal establishes rotational reference points on the 
recording surface. Each track may be divided into sectors with 
the initial sector ("Zero") starting coincident with the Index 
Pulse. All subsequent sectors start coincident with the active 
going edge of a Sector Pulse. When the Index Pulse is activated, 
the Sector Pulse is omitted. 


Address Mark, which is an optional signal, indicates device 
detection of a previously recorded Address Mark when Read Gate 
and Address Mark Control are both active. Only one inactive to 
active transition of Address Mark is made for each assertion of 
an Address Mark Control signal -active when the Read Gate signal 


is active. 


Whenever the device is ready and the head carriage is not in 
motion, a valid Sector/Address Mark Signal shall be transferred 
from the selected device to the host. When the head carriage is 
in motion or the device is not ready the Sector/Address Signal 
may or may not be valid (see vendor specification). 


3.2.11 Read Gate 


The Read Gate Signal is transferred from the host to the selected 
device. 


The Read Gate Signal enables and synchronizes the read circuitry 
to transfer the serialized data information on the Read Data 
lines from the recording medium. If the address mark option is 
utilized, Read Gate and Address Mark Control shall enable the 
device to search for a previously recorded Address Mark. 
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3.2.12 Write Gate 


The Write Gate Signal is transferred” from the host to the 
selected device. 


The Write Gate Signal enables the write circuitry in the device 
to transfer the serialized information on the Write Data lines to 
the recording medium. If the address mark option is implemented, 

the device shall record an Address Mark on the medium when write 
Gate and Address Mark Control are active. Note, a write operation 
shall not take place unless a write enable condition has been 
established by a previous Write Control Command. 


3.2.13 Address Mark Control (optional) 


The Address Mark Control signal is transferred from the host to 
the selected device. 


Address Mark Control is used in conjunction with Read Gate or 
Write Gate, for the detection of or writing of an Address Mark on 
the data surface. 


The Address Mark Control Signal shall be inactive if the address 
mark option is not used or not implemented. Devices that do not 
use the address mark option padi: ‘still -provide--the specified 


terminating resistors. 
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3.3 Read/write Signals 


This section describes the signals used when transferring data to 
and from the host, These signals are only valid if a device is 
selected. All of these signals are driven differentially ( see 
Section 2.4.3). All data sent to the device or host shall be 


Non-Return-to-Zero (NRZ). 


3.3.1 Read Data 


When Read Gate is active, the Read Data lines transfer the serial 
NRZ read data from the selected device to the host. This data is 
synchronized with Read Clock. The Read Data signal shall be 
static when Read Gate is not active. 


3.3.2 Read/Reference Clock 


The Read/Reference Clock is transferred from the selected device 
to the host. This signal shall transfer Read Clock when Read Gate 
is active. Read Clock shall be synchronous with the serial NRZ 
read data. This signal shall transfer the Reference Clock at all 


other times. 


3.3.3 Write Data 


-When Write Gate is active, the Write Data lines shall transfer 
the serial NRZ write data from the host to the selected device 
for recording. The serial write data shall be synchronized to the 
Write Clock. This signal shall be held static at all times except 


when Write Gate is active. 


3.3.4 Write Clock 


Write Clock shall be used by the selected device to properly 
phase the Write Data lines while recording. Write Clock shall be 
generated in the host by returning the Reference Clock Signal 
back to the selected device at the same frequency with an 
unspecified but constant shift in phase. This signal shall be 
held static at all times except when used to precede the active 
going edge of Write Gate by at least one bit cell but not more 


than 16 bit cells and when Write Gate is active. 
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4.8 Command Structure 


All command, status, and parameter information passed between the 
selected device and the host shall be transferred via the Control 
Bus and shall conform to the command protocol defined in this 


standard. 


The command protocol requires that each command sequence consists 
of a two byte transfer. The first byte, the Command Byte, shall 
always be transferred from the host to the selected device. The 
second byte, the Parameter Byte, may be transferred from the host 
to the selected device or from the selected device to the host. 
The direction of the transfer of the Parameter Byte is determined 
by the state of the Bus Direction Out signal. 


Command Codes 89-FF Hex are reserved for commands outside the 
scope of this standard. It is desirable that this device dependent 
level interface operate with an as yet undefined higher level 
interface, By reserving the most significant bit of the Command 
Code a simple check can identify commands that are either executed 
or passed on by such a higher-level interface. If .a reserved 
command is received, the device shall set the Attention Condition 
and the Illegal Command Bit in the General Status Byte. -- 


The Command Byte therefore, indicates the particular function that 
the selected devicé is to perform. This may include functions such 
as accepting parametric information from the host, performing 
requested head motion, or reporting specific status conditions. 
The Command Byte also conditions the device as to the direction of 
the transfer of the Parameter Byte portion of the command 


sequence. 


The Parameter Byte completes the command sequence by providing the 
parameter or status’ information demanded by the Command Byte. In 
cases where the Command Byte is sufficient to indicate the 
complete nature of- the command, the General Status Byte is 
transfered as Parameter Byte to complete the command sequence. 


Below all defined. command sequences are specified. They are 
divided into two groups: one which requires the Parameter Byte 
transferred to the device (Parameter Out) and one which requires 
the Parameter Byte transfered to the host (Parameter In). Note 
that there is a further subdivision in each group. There are 
certain mandatory commands which shall be implemented in all 
devices conforming to this standard. There is a second class of 
commands that are defined but may or may not be implemented in a 
particular vendor's device. In a third class of commands vendors 
may implement unique commands which are not defined in this 


standard. 
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There are two kinds of commands: 


Immediate Commands and Time Dependent Commands. 


For Immediate Commands the active going edge of the second Bus 
Acknowledge shall not be generated until the required action has 
been performed. In the case that action is not performed, 
Attention Condition shall be set prior to the active going edge of 
the Bus Acknowledge Signal that is returned as a response to 


Parameter Request. 


For Time Dependent Commands the Attention Condition shall be set 
when the action for the Time Dependent Command is completed. The 
resetting of the Attention Condition by the Immediate Command, 
Clear Fault or Clear Attention, completes the Time Dependent 
Command. 


All commands, once in progress, shall proceed to completion 
utilizing parameters established prior to the issuance of the 
command. While a Time Dependent Command (denoted in Tables 4-1 and 
4-2 by a *) is in progress and, if the device is not busy, a new 
Time Dependent Command is issued, the new Time Dependent Command 
shall be rejected by setting the Attention Condition and the 


Command Reject Bit in Sense Byte l. 


A new Time Dependent Command may be issued only after the current 
Time Dependent Command has completed. 


Also, while a Time Dependent Command is in progress, the device 
shall accept Immediate Commands if not busy. 


While all commands are defined individually, there are logical 
groupings of commands that represent functional operations. For 
example, the loading of parameter information (cylinder address) 
and the execution .of a particular operation (seek). Unusual 
command sequences within such groupings may result in violations © 
of an implied protocol and will cause responses which are 
implementation dependent and will vary among vendors. 


It should be noted that in some implementations such violations 
may cause a loss of data or functional error with or without an 


error indication. The user is urged to consult vendors's 
specifications to determine what results, if any, are defined for 
such command sequences. 
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Table 4-1 Commands With Parameters Out 
Function Command Code Parameter Out 


Attention Control 40 Hex Bit 7 
@ = Enable Attention 


1 = Disable Attention 


Write Control ~ - 41 Hex Bit :7 
1 = Write Enable 


, 8 Write Disable 
Set Upper Cyl. Address 42 Hex MSB of Cylinder Address 
Set Lower Cyl. Address 43 Hex LSB of Cylinder Address 
Select Moving Head 44 Hex Head Number 
Load Attribute Number 5@ Hex Address Byte 
Load Device Attribute 51 Hex Information Byte 
Select Fixed Head 52 Hex Head address 
Read Control 53 Hex Bits 7,6 

OX nominal Strobe 


19 = Strobe Early 


11 Strobe Late 
Offset Control * 54 Hex Bits 7,6 
OX no Offset 


19 = Offset Forward 


11 Offset Reverse 
Spin Control *- -. 55 Hex Bit 7 . 

1 = Spin Up 

@ = Spin Down 
Load Bytes Per Sec. High 56 Hex MSB of Bytes Per Sector 
Load Bytes Per Sec. Med. 57 Hex MedSB of Bytes Per Sector 
Load Bytes Per Sec. Low. -.58 Hex LSB of Bytes Per Sector - 
Load Sec. Pulses Per  .- ~ MSB of Sector Pulses — 
Track High 59 Hex Per Track 
Load Sec. Pulses Per MedSB of Sector Pulses 
Track Medium 5A Hex Per Track 
Load Sec. Pulses Per. . LSB of Sector Pulses 
Track Low 5B Hex Per Track 
Load Read Permit High 6B Hex MSB of Cylinder Address 


Load Read Permit Low 6C Hex LSB of Cylinder Address 
Read enabled only 
on Cyl. equal to or 
: greater than the above, 
Load Write Permit High 6D Hex MSB of Cylinder Address 


Load Write Permit Low 5E Hex LSB of Cylinder Address 
Write enabled only 


on Cyl. equal to or 
greater than the above. 


Load Test Byte 6F Hex Test Byte 


Commands with codes 48 Hex through 4F Hex are mandatory commands, 
whereas, commands with codes 58 Hex to 6F Hex are optional. 


The code range of 70 = 7F Hex is reserved for unique vendor 
applications. All unused bits in parameters shall be zero. 


The commands with a "*" appended are Time Dependent Commands that 
generate an Attention Condition upon completion. 
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Table 4-2 


Commands With Parameters In 


Command Code 


Parameter -In - 


Function 

Report ‘Illegal Cmd.' @@ Hex General Status 
Clear Fault @1 Hex General Status: 
Clear Attention @2 Hex General Status 
Seek * @3 Hex General Status 
Rezero * 04 Hex General Status 
Report Sense Byte 2** @D Hex Sense Byte 2 
Report Sense Byte 1** GE Hex Sense Byte 1 
Report General Status** OF Hex > General Status 


ee a 
Device Attribute Byte 


Report Device Attribute 18 Hex 
Set Attention * 11 Hex 
Reserve Device : "12 Hex 
Release Device 13 Hex 
Selective Reset *~- °°: ~-+-]4-Hex 
Seek to Landing Zone * £15 Hex 
Partition Track * 16. Hex 
Report Cyl. High 29 Hex 
Report Cyl. Low 2A Hex 
Report Read Permit High 2B Hex 
Report Read Permit Low-_  2C Hex 
Report Write Permit High 2D Hex 


Report 
Report 


Commands with codes @@ Hex through @F Hex are mandatory commands, 


Write Permit Low 2E 
Test Byte 


Hex 
2F Hex 


General 
General 
General 
General 
General 
General 
MSB of 
LSB of 
MSB of 


_LSB of 
“ MSB of 


LSB of 


Status 
Status 
Status 
Status 
Status 
Status 
Cylinder 
Cylinder 
Cylinder 
Cylinder 
Cylinder 


Cylinder 


Echo Byte 


Address 
Address 
Address 
Address 
Address 
Address 


whereas, commands with codes 18 Hex to 2F Hex are optional. 


The code range of 38 - 3F Hex ‘is reserved for unique vendor 


applications. All unused bits in parameters shall be zero. 


The commands with '*' appended are Time Dependent Commands that 


set an Attention Condition upon completion. 


** Events reported 


Attention Condition even without a preceding command. 
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4.1 Commands With Parameter Out 


All commands defined in this section require a Parameter Byte to 
be transferred to the device. These commands are summarized in 


Table 4.1. 


4.1.1 Mandatory Commands 

All commands defined in this section shall be implemented in all 
devices. 

4.1.1.1 Attention Control (Command Code 4@ Hex) 

This command shall condition the selected device to enable or 


disable its attention circuitry based on the value. of the 
Parameter Byte as shown below. 


7 6 5 4 3 2 1 @ 
foe fren Ce ee fo---- en ay 
| 1 @ | 6 | 6 | @ | @ | @ | 6 I 
focea- foe foananpenaa- fo---- fannn- prnnnn penne t 

| 

@ = Enable Attention 


= Disable Attention 


[~) 
1 


This command allows the host -to selectively ignore attention 
requests from certain devices on the’ interface. -This might be done 
in response to a device ERat generates spurious attention requests 


due to a malfunction. 


The Enable Attention .Command shall cause the selected device to 
gate its internal Attention Condition onto the party line ("wired 
OR") Attention Signal. The Disable Attention Command shall cause 
the selected device to disable the gating of the internal 
Attention Condition onto the party line Attention Signal. This 
command shall have no impact on the function of the radial status 
returned with the Attention In Strobe Signal (see Section 3.2.3.2) 


Devices shall be initialized with the Attention circuitry enabled. 
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4.1.1.2 Write Control (Command Code 41 Hex) 


This command shall condition the selected device to enable or 
disable its write circuitry based on the value of the Parameter 


Byte as shown below. 


1 = Write Enable 
= Write Disable 


This command is used in conjunction with the Write Gate Signal and 
therefore merely enables the write circuitry while the Write Gate 
Signal activates the circuitry at the proper time. An active Write 
Gate Signal while the device's write circuitry is disabled shall 


result in no data being recorded. 
Devices shall be initialized with the write circuitry disabled. 


A Write Control Command executed during a write operation is a 
violation of protocol. 


4.1.1.3 Set Upper Cylinder Address (Command Code 42 Hex) 


This command shall condition the selected device to accept the 
Parameter Byte as the most significant byte of a cylinder address. 


This command is used in conjunction with the Seek Command (see - 
Section 4.2.1.4) and therefore is a means of supplying the most 


-Significant byte of a target cylinder address. 


This command shall not cause any head motion. Loading a cylinder 
address outside the range of a device shall not cause an error 
unless a subsequent Seek Command is issued to that illegal 


cylinder. 


Devices shall be initialized with the target cylinder address 
equal to zero. 
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4.1.1.4 Set Lower Cylinder Address (Command Code 43 Hex) 


This command shall condition the selected device to accept the 
Parameter Byte as the least significant byte of a cylinder 


address, 


This command is used in conjunction with ‘the Seek Command: (see. 
Section 4.2.1.4) and‘therefore is a means.of supplying>the least. 
significant byte of a target cylinder address. 


This command shall not cause any head motion. Loading a cylinder 
address outside the range of a device shall not cause an error 
unless a subsequent seek command is issued to that illegal 


cylinder. 


Devices shall be initialized with the target cylinder address 
equal to zero. 


4.1.1.5 Select Moving Head (Command Code 44 Hex) 


This command shall condition the selected device to accept the 
Parameter Byte as the binary address of the head selected for read 
or write operations. This command shall enable the moving heads 


and shall disable the fixed heads. 


A Select Moving Head Command issued during a read or write 


operation is a violation of protocol. 


The device shall set the Attention Condition and the Illegal 
Parameter Bit in the General Status Byte upon receipt of a head 
address outside the head address range of the device. 


Devices shall be initialized with moving head zero selected. 
4.1.1.6 Reserved Mandatory Commands 


Command Codes 45 Hex through 4F Hex are reserved for future 
mandatory Parameter Out Commands. : 
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4.1.2 Optional Commands 


Commands defined in this section may or may not be implemented in 
a particular device. Individual vendor's specifications should be 


consulted. 


Issuance of an optional command to a device in which it is not 
implemented shall set the Attention Condition and the Illegal 


Command Bit in the General Status Byte. 


4.1.2.1 Load Attribute Number (Command Code 50 He x) 


This command shall condition the selected device to accept the 
Parameter Byte as the number of a Device Attribute as defined in 
Table 4-3. This command prepares the device for a subsequent Load 
Device Attribute Command or Report Device Attribute Command (see 
Sections 4.1.2.2 and 4.2.2.1). This command may be issued at any 


time. 


4.1.2.2 Load Device Attribute (Command Code 51 Hex) 


This command shall condition the selected device to accept the 
Parameter Byte as the new value of a Device Attribute. The number 
of the Device Attribute must have been previously defined by the 
Load Attribute Number Command (see Section 4.1.2.1). 


4.1.2.3 Select Fixed Head (Command Code 52 Hex) 


This command shall condition the selected device to accept the 
Parameter Byte as the binary head address of the fixed head to be 
accessed during a-read or write operation. This command shall 
enable the fixed heads and shall disable the moving heads. 


7 ) £5 4 3 2 1 4) 
faaaa- $a---- $o---- faana- $----- foanan- $o---- faasec- + 
| Fixed Head Address | 
$a---- fa---- taa--- $aa--- fa---- $oe--- $----- fanan- + 


Any head selection command issued during a read or write operation 
is a violation of protocol. 


The device shall set the Attention Condition and the Illegal 
Parameter Bit of the General Status Byte upon receipt of a head 
address outside the head address range of the device. 


Devices shall be initialized with the fixed heads disabled. 
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4.1.2.4 Read Control (Command Code 53 Hex) 


This command shall condition the selected device to modify its 
read timing. The modification of _the timing is defined by the 
value of the Parameter Byte as shown below. 


7 6 5 4 3 2 1 i) 
$aaeen es foaaa- faanne faann- $o---- foannn $2a--- + 
| | 9 | o@fe8 t.@e@ | 6 | 8 | 
+aanen fe---- f-2---- +2--—- o-e-- taanen- $----- faaaan + 

| | ' 

| | 

] X = Nominal Strobe 

1 @ = Strobe Early 

1 1 = Strobe Late 


X = don't care 


When set, the read control shall remain in the one state and will 


only return to 
Command, Rezero 


the Nominal Strobe state by a new Read Control” 
Command or Initial State. 


The device shall be initialized with Nominal Strobe timing. 
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4.1.2.5 Offset Control (Command Code 54 Hex) 


This command shall condition the selected device to modify the 
position of the moving head(s). The offset modification is defined 


by the value of the Parameter Byte as shown below. » 


7 6 5 4 3 2 1 ) 
faane- fe---- taeerepennn- +----- facne- fo---- +ae--- + 
] | | @ | 6 1.6 | @ | @ | 6 | 
fran napecnn- face-- faann- $2---- fare nnpannn- panna + 

| | 

| | 

g X = No Offset 

1 @ = Offset Forward 

1 1 = Offset Reverse 7 


X = don't care 


The offset control shall be reset to No Offset positioning by 
every Seek Command, Rezero Command or Initial State. 


Furthermore, the setting of any offset has the effect of disabling 
the write circuitry and any write operation attempted shall set 
the Attention Condition and the Command Reject Bit in Sense Byte 


1. 


The Offset Control Command is in effect a seek command and as such 
shall set the Attention Condition upon the completion of the 


offset operation. - 


The device shall be initialized with no offset. 
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4.1.2.6 Spin Control (Command Code 55 Hex) 


This command shall condition the selected device to enter a spin 
up or spin down cycle based on the value of the Parameter Byte as 


shown below. 


7 6 5 4 3 2 1 1) 
foccc- t----- ta---- focaan faten foaaa- fasc-- +----- + 
| | @ | o@iteit ote test eo i 
$a---- +----- f2aan- taaan- ta---- +----- +----- poaccnet 

| 

| 

1 = Spin Up 

@ = Spin Down 


A spin up cycle shall consist of starting the rotation of the 
spindle. A spin down cycle shall consist of stopping the rotation 
of the spindle. 


Upon completion of a spin control cycle the device shall set the 
Attention Condition. Issuing a spin up command to a device whose 
spindle is already at full speed or issuing a spin down command to 
a device whose spindle has already stopped shall also set the 
Attention Condition. 


See vendor specification for initial state of the Spin Control. 
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4.1.2.7 Load Bytes Per Sector High (Command Code 56 Hex) 


This command shall condition the selected device to accept the 
Parameter Byte as the most significant byte of a 24 bit number 
that represents-the total number of bytes that will occur between 
active going edges of sector pulses, and between the active going 
edge of the Index Pulse and the active going edge of the first 
Sector Pulse when a Partition Track Command (see Section 4.2.2.5) 
is executed. 


This command is used’ in conjunction with the Partition Track 
Command and is a means-of supplying the most significant byte of- 


the Bytes Per Sector value. 


Upon completion of the execution of the Partition Track Command 
the contents of this byte will be set into the Bytes Per Sector 
High Attribute =(13 Hex). See Table 4-3 and section 4.3.12. 


This command functions in conjunction with the Load Bytes Per 
Sector Medium and Low Commands (see Section 4.1.2.8&9) and 


operates in the same way. 


4.1.2.8 Load Bytes Per Sector Medium (Command Code 57 Hex) 


This command shall condition the selected device to accept the 
Parameter Byte as the medium significant byte of a 24 bit number 
that represents the total number of bytes that will occur between 
active going edges of sector pulses, and between the active going 
edge of the Index Pulse and the active going edge of the first 
Sector Pulse when a Partition Track Command (see Section 4.2.2.5) 


is executed. 


This command--is used: in conjunction with the. Partition.-Track 
Command and is a means of supplying the medium significant byte of 
the Bytes Per Sector value. 


Upon completion of the execution of the Partition Track Command 
the contents of this byte will be set into the Bytes Per Sector 
Medium. Attribute (14 Hex). See Table 4-3 and section 4.3.13. 


This command functions in conjunction with the Load Bytes per 
Sector High and Low Commands (see Section 4.1.2.7&9) and operates. 


in the same way. 
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4.1.2.9 Load Bytes Per Sector Low (Command Code 58 Hex) 


This command shall condition the selected device to accept the 
Parameter Byte as the least significant byte of a 24 bit number 
that represents the total number of bytes that will occur between 
active going edges of sector pulses, and between the active going 
edge of the Index Pulse and the active going edge of the first 
Sector Pulse when a Partition Track Command (see Section 4.2.2.6) 
is executed, 


This command is used in conjunction with the Partition Track 
Command and is a means of supplying the least significant byte of 
the Bytes Per Sector value. 


Upon completion of the execution of the Partition Track Command 
the contents of this byte will be set into the Bytes Per Sector 
Low Attribute (15 Hex). See Table 4-3 and section 4.3.14. 


This command functions in conjunction with the Load Bytes Per 
Sector High and Medium Commands (see Section 4.1.2.7&8) and 
operates in the same way. 


4.1.2.1@ Load Sector Pulses Per Track High (Command Code 59 Hex) 


This command shall condition the selected device to accept the 
Parameter Byte as the most significant byte of a 24 bit number 
that represents the total number that will control the number of 
sector pulses between (but excluding) Index Pulses generated by 
hard sectored devices when a Partition Track Command (see Section 


4.2.2.6) is executed. 


This command is used in conjunction with the Partition Track 
Command and is a means of supplying the most significant byte of 
the Sector Pulses Per Track value. 


Upon completion of the execution of the Partition Track Command 
the contents of this byte will be set into the Sector Pulses Per 
Track High Attribute (16 Hex). See Table 4-3 and section 4.3.15. 


This command functions in conjunction with the Load Sectors Per 
Track Medium and Low Commands (see Section 4.1.2.11&12) and 
operates in the same way. 
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4.1.2.11 Load Sector Pulses Per Track Medium (Command Code 5A He x) 


This command shall condition the selected device to accept the 
Parameter Byte as the medium significant byte of a 24 bit number 
that represents the total number that will control the number of 
sector pulses between (but excluding) Index Pulses generated by 
hard sectored devices when a Partition Track Command (see Section 


4.2.2.5) is executed. 


This command is used in conjunction with the Partition Track 
Command and is. a means of supplying the medium significant byte of 
the Sector Pulses Per Track value. 


Upon completion of the execution of the Partition Track Command 
the contents of this byte will be set into the Sector Pulses Per 
Track Medium Attribute (17 Hex). See Table 4-3 and section 4.3.14. 


This command functions in conjunction with the Load Sectors Per 
Track High and Low Commands (see Section 4.1.2.10&12) and operates 
in the same way. ; 


4.1.2.12 Load Sector Pulses Per Track Low (Command Code 5B Hex) 


This command shall condition the selected device to accept the 
Parameter Byte as the least significant byte of a 24 bit number 
that represents the total number that will control the number of 
sector pulses between (but excluding) Index Pulses generated by 
hard sectored devices when a Partition Track Command (see Section 
4.2.2.6) is executed. 


This command is used in conjunction with the Partition Track 
Command and is a means of supplying the least significant byte of 
the Sector Pulses Per Track value. 


Upon completion of the execution of the Partition Track Command 
the contents of this byte will be set into the Sector Pulses Per 
Track Low Attribute (18 Hex). See Table 4-3 and section 4.3.17. 


This command functions in conjunction with the Load Sectors Per 


Track High and medium Commands (see Section 4.1.2.19&11) and 
operates in the same way. 
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4.1.2.13 Load Read Permit High (Command Code 6B Hex) 

This command shall condition the selected device to accept the 
Parameter Byte as the most significant byte of a 16 bit cylinder 
address defining a programmable read permit area on the device. 


The device shall allow read operations to occur only on cylinders 
with an address equal to or greater than the cylinder address 


programmmed in the device via this command. 


Issuing this command while Read Gate is active is a violation of 
protocol. 


The device shall initialize Read Permit High to zero. 


4.1.2.14 Load Read Permit Low (Command Code 6C Hex) 

This command shall condition the selected device to accept the 
Parameter Byte as the least significant byte of a 16 bit cylinder 
address defining a programmable read permit area on the device. 


This command functions in conjunction with the Load Read Permit 
High Command (see Section 4.1.2.13) and operates in the same way. 


The device shall initialize Read Permit Low to zero. 


4.1.2.15 Load Write Permit High (Command Code 5D Hex) 

This command shall condition the selected device to accept the 
Parameter Byte as the most significant byte of a 165 bit cylinder 
address defining a programmable write permit area on the device. 
The device shall allow write operations to occur only on cylinders 
with an address equal to or greater than the cylinder address 
programmmed in the device via this command. 


Issuing this command while Write Gate is active is a violation of 
Protocol. : 


The device shall initialize Write Permit High to zero. 


4.1.2.16 Load Write Permit Low (Command Code 6E Hex) 

This command shall condition the selected device to accept the 
Parameter Byte as the least significant byte of a 16 bit cylinder 
address defining a programmable write permit area on the device. 


This command functions in conjunction with the Set Write Permit 
High Command (see Section 4.1.2.15) and operates in the same way. 


The device shall initialize Write Permit Low to zero. 
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4.1.2.17 Load Test Byte (Command Code 45F Hex) 
This command shall condition the selected device to accept the 


Parameter Byte aS a special test byte that shall be returned to 
the host as part of the Report Test Byte Command (see Section 


4.2.2.13). 


This command pair allows the host to test the integrity of data 
transfer over the Control Bus. 


4.1.2.18 Reserved Optional Commands 


Command Codes SC Hex through 6A Hex are reserved for future 
optional Parameter Out Commands. 


4.1.2.19 Vendor Unique Commands 
Command Codes 79 Hex through 7F Hex are reserved for commands with 


Parameter Out that may be defined solely by the individual vendor. 
Particular device specifications should be consulted. 
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4.2 Commands with Parameter In 


The commands defined in this section require a Parameter Byte to 
be transferred to the host. These commands are summarized in Table 


4.2. 


4.2.1 Mandatory Commands 


All commands defined in this section shall be implemented in all 
devices. 


4.2.1.1 Report "Illegal Command" (Command Code @@ Hex) 


This command shall force the Illegal Command Bit to be set in the 
General Status Byte (see Section 4.4). The General Status Byte, 
with the Illegal Command Bit equal to one, is returned to the host 
by the Parameter Byte of the command sequence, 


4.2.1.2 Clear Fault (Command Code @1 Hex) 


This command shall cause all fault status bits of the selected 
device to be reset, provided the fault condition has passed. If 
the fault condition persists the appropriate status bit shall 
continue to be equal to one. The General Status Byte, cleared of 
previous fault status, shall be returned by the Parameter Byte of 


the command sequence. 


The Clear Fault Command shall also reset the Attention Condition 
caused by the fault condition, again only if the fault condition 
no longer exists. ; 
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4.2.1.3 Clear Attention (Command Code @2 Hex) 


This command shall cause the Attention Condition to be reset in 
the selected device. The General Status Byte shall be returned by 
the Parameter Byte of the command sequence, 


If the error or other condition that caused the Attention 
Condition persists, the Attention Condition shall not be set 
again. If, however, the condition is reset and then the error 
reoccurs, the Attention Condition shall be set again. 


4.2.1.4 Seek (Command Code @3 Hex) 


This command shall cause the selected device to seek to the 
cylinder identified as the target cylinder by the Load Cylinder 
Address Commands (see Section 4.1.1.3 and 4.1.1.4). The General 
Status Byte shall be returned to the host by the Parameter Byte of 


the command sequence. 


The Seek Command shall set the Attention Condition and the Illegal 
Parameter Bit in the General Status Byte if the target cylinder 
address is outside the cylinder address range of the device. 


Upon the completion of any seek (including a zero length seek) the 
device shall set the Attention Condition. 


This command shall reset the Offset Control to no offset. 


4.2.1.5 Rezero (Command Code 94 Hex) 


This command shall cause the selected device to position the 
moving head(s) over cylinder zero and reset Read Control to 
nominal strobe and the Offset Control to no offset. The General 
Status Byte shall be returned to the host by the Parameter Byte of 


the command sequence. : 


Upon the completion of the positioning of the moving head(s) over 
cylinder zero the device shall set the Attention Condition. 


4.2.1.6 Report Sense Byte 2 (Command Code §D Hex) 


The command shall cause the selected device to return Sense Byte 2 
by the Parameter Byte of the command sequence. No other action 


shall be taken in the device. 
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4.2.1.7 Report Sense Byte 1 (Command Code GE Hex) 


This command shall cause the selected device to return Sense Byte 
1 by the Parameter Byte of the command sequence. No other action 
shall be taken in the device. 


4.2.1.8 Report General Status Byte (Command Code @F Hex) 


This command shall cause the selected device to return the General 
Status Byte by the Parameter Byte of the command sequence. This 
command shall not perform any other function in the device and 
acts aS a “no-op" in order to allow the host to monitor the 
device's General Status Byte without changing any device 
condition. 


4.2.1.9 Reserved Mandatory Commands 


Command Codes @5 Hex through @C Hex are reserved for future 
mandatory Parameter In Commands. 


4.2.2 Optional Commands 


Commands defined in this section may or may not be implemented in 
a particular device. Individual vendor's specifications should be 


consulted, 


Issuance of an optional command to a device in which it is not 
implemented shall set the Attention Condition and the Illegal 
Command Bit in the General Status Byte. 


4.2.2.1 Report Device Attribute - (Command Code 19 Hex) 

This command shall cause the selected device to return a byte of 
information that is the Device Attribute whose number was defined 
in the Load Attribute Number Command (see Section 4.1.2.1). The 
contents of the byte is defined by Table 4-3 and Section 4.3. 
4.2.2.2 Set Attention (Command Code 11 Hex) 


This command shall cause the selected device to set the Attention 
Condition. No other action shall be caused. 


The General Status Byte shall be transferred to the host by the 
Parameter Byte of the command sequence. 
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4.2.2.3 Multiported Devices 


The following two commands: Reserve Device and Release Device, 
shall be only valid with devices that have more than one port. 


Reserving a device shall cause it to act upon commands from the 
reserving port only and either totally disregard all other ports, 
eg. alternate ports, by making Busy active or only respond to 
status request commands from the alternate ports. 


A device may be implicitly or explicitly reserved to a port 
thereby limiting a device's activity with respect to the alternate 
ports. 


A device shall be implicitly reserved to a port whenever it has 
been selected from that port and remains reserved until it has 


been deselected. 


A device shall be explicitly reserved by a Reserve Device Command 
and remains reserved until explicitly released by a Release Device 
Command from the same port or a Forced Release from an alternate 


port. 


Multiported devices shall have two types of status reporting, 
Common Status and Port Specific Status. Common Status shall be 
reported to all ports while Port Specific Status shall be only 
reported to the port that issued the command when the status was 
set. Port Specific Status shall only be cleared by the port to 
which it is port specific. Common Status, unless self clearing, 


shall be cleared individually by each port. 


A Forced Release shall occur if a device is reserved and there is 
a detection of Port Enable transistion from the active to the 
inactive state and all Control Bus Bit @-7 Lines are active. A 
Forced Release shall .cause the device to release the reserved - 
port, set the Forced Release Bit in Sense Byte 2 and set the 
Attention Condition to the port that was previously reserved. 


In a multiported device, the inactive state of the Port Enable 
signal on one port shall not cause other ports to become disabled. 


Errors are only reported to the port where the error occurred or 
the port that initiated the operation. 


Powering down a device shall release the reserved port. 
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“A4.2.2.3.1 Reserve Device (Command Code 12 Hex) 


This command shall cause the selected device to be reserved to the 
port through which this command was received. 


Bit 4 of Sense Byte 2 of the alternate ports shall be set, and bit 
2 of Sense Byte 2 of the reserving port shall be set. 


The device may then either (at the discretion of the vendor) make 
Busy active on the alternate ports or accept a Report General 
Status Command, Report Sense Byte 1 Command, or Report Sense Byte 
2 Command. If the latter approach is used only these commands are 
valid. All other commands shall be rejected by setting the 
Attention Condition and the Command Reject Bit in Sense Byte l. 


4.2.2.3.2 Release Device (Command Code 13 Hex) 


This command shall cause the selected device to be released. Bit 4 
of Sense Byte 2 of the alternate ports shall be reset and bit 2 of 


Sense Byte 2 of the reserving port shall be reset. 


After deselection the device shall then be available for either 
implicit or explicit reserving by any port. 


4.2.2.4 Selective Reset (Command Code 14 Hex) 


This command shall cause the selected device to reach Initial 
State (see Section 3.2.1). This is a time dependent command. All 
resetable parameters, attentions, errors, etc., shall be reset 
Prior to the assertion of the acknowledge to parameter request and 
shall be reflected in the returned General Status Byte. Upon 
completion of the parameter byte transfer the device shall go to 
the initial state. When the initial state is reached bit @ of 
Sense Byte 2 will. be set. (This causes the setting of the 


Attention Condition). 


4.2.2.5 Seek to Landing Zone (Command Code 15 Hex) 


This command shall cause the selected device to seek to a 
defined landing zone. The General Status Byte with Not Ready bit 
set shall be returned to the host by the Parameter Byte of the 
command sequence, 


Upon completion of the positioning of the moving head(s) over the 
landing zone the device shall set the Attention Condition. If the 


device cannot successfully seek to the landing zone it shall set 
the Attention Condition and set bit @ of Sense Byte l. 
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4.2.2.6 Partition Track (Command Code 16 Hex) 


This command shall cause the selected device to reconfigure the 
arrangement of Sector Pulse generation according to parameters 
received via the Load Bytes Per Sector and/or the Load Sector 
Pulses Per Track Commands (see Section 4.1.2.7 to 4.1.2.12). The 
General Status Byte shall be returned to the host by the Parameter 


Byte of the command sequence. 


Upon the completion of execution of this command the Bytes Per 
Sector and the Sector Pulses Per Track will be updated in the 
Attribute Table and also bit 6 of Attribute byte 3E Hex will be 


cleared and this shall set the Attention Condition. 


The Partition Track Command shall set the Attention Condition and 
the Illegal Parameter Bit in the General Status Byte if the Bytes 
Per Sector and/or the Sector Pulses Per Track create a set that is 


outside the range of the device. 


Issuing this command while Read Gate or Write Gate is active or 
activating Read Gate or Write Gate while this command is executing 


is a violation of protocol. 


4.2.2.7 Report Cylinder High (Command Code 29 Hex) 


This command shall cause the selected device to return a byte of 
information that is the most significant byte of a 16 bit number 
that indicates the cylinder address of the current position of the 
moving heads. This number shall not reflect the most recent 
cylinder address set by the Set Cylinder Address Commands (see 
Sections 4.1.1.3 and 4.1.1.4) unless there has been an intervening 


Seek Command completed (see Section 4.2.1.4). 


If executed during-a. seek operation, the information returned 
shall be ascertained by the vendor specification. 


The information shall be transferred by the Parameter Byte of the 
command sequence, 
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4.2.2.8 Report Cylinder Low (Command Code 2A Hex) 


This command shall cause the selected device to return a byte of 
information that is the least significant byte of a 16 bit number 
that indicates the cylinder address of the current position of the 
moving heads. This number shall not reflect the most recent 
cylinder address set by the Set Cylinder Address Commands (see 
Sections 4.1.1.3 and 4.1.1.4) unless there has been an intervening 


Seek Command completed (see Section 4.2.1.4). 


If executed during a seek operation, the information returned 
shall be ascertained by the vendor specification. 


The information shall be transferred by the Parameter Byte of the 
command sequence, 


4.2.2.9 Report Read Permit High (Command Code 2B Hex) 


This command shall cause the selected device to return a byte of 
information that is the most significant byte of a 16 bit number 
that indicates the minimum cylinder address accessible for read 
operations. This number is programmed by the Load Read Permit 
Commands. (See Sections 4.1.2.13 and 4.1.2.14.) 


The information shall be transferred by the Parameter Byte of the 
command sequence. 


4.2.2.198 Report Read Permit Low (Command Code 2C Hex) 


This command shall cause the selected device to return a byte of 
information that is the least significant byte of a 16 bit number 
that indicates the minimum cylinder address accessible for read 
operations. This number is programmed by the Load Read Permit 


Command (see Sections 4.1.2.13 and 4.1.2.14.) 


The information shall be transferred by the Parameter Byte of the 
command sequence. 


4.2.2.11 Report Write Permit High (Command Code 2D Hex) 


This command shall cause the selected device to return a byte of 
information that is the most significant byte of a 15 bit number 
that indicates the minimum cylinder address accessible for write 
operations. This number is programmed by the Load Write Permit 


Commands. (See Sections 4.1.2.15 and 4.1.2.16.) 


The information shall be transferred by the Parameter Byte of the 
command sequence. 
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4.2.2.12 Report Write Permit Low (Command Code 2E Hex) 


This command shall cause the selected device to return a byte of 
information that is the least significant byte of a 16 bit number 
that indicates the minimum cylinder address accessible for write 
operations. This number is programmed by the Load Write Permit 
Commands. (See Sections 4.1.2.15 and 4.1.2.16.) 


The information shall be transferred by the Parameter Byte of the 
command sequence. 


4.2.2.13 Report Test Byte (Command Code 2F Hex) 


This command shall cause the selected device to return a copy of 
the Test Byte transferred to the device via the Load Test Byte 


Command. (See Section 4.1.2.17.) 


The Test Byte shall be transferred by the Parameter Byte of the 
command sequence. 


4.2.2.14 Reserved Optional Command 

Command Codes 17 Hex through 28 Hex are reserved for future 
optional Parameter In Commands. 

4.2.2.15 Vendor Unique Commands 

Command Codes 38 Hex through 3F Hex are reserved for commands with 


Parameter In that may be defined solely by the individual vendor. 
Particular device specifications should be consulted. 
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Table 4-3 


Device Attribute 


i ee ene nan a ni hana ee ee ee ee eee 


Attribute 


ee ec tk eh eh hy el th hy il sy A ly a Ah le th eh ch th le th th hh ho ole A a a kh Ok Oo th Oh eh a a a OR Oh RS 


User ID 

Model ID High 
Model ID Low 
Revision ID 

Device Type ID 
Table Modification 
Table ID * 


Bytes Per Track High 
Bytes Per Track Med. 
Bytes Per Track Low 
Bytes Per sector High 
Bytes Per sector Med. 
Bytes Per sector Low 

Sec Pulses Per Track High 
Sec Pulses Per Track Med. 
Sec Pulses Per Track Low 
Sectoring Method 


Number of Cylinder High 
Number of Cylinder Low 
Number of Moving Heads 
Number of Fixed Heads 


Encoding Method #1 
Preamble #1 Length 
Preamble #1 Pattern 
Sync #1-Pattern 
Postamble #1 Length 
Postamble #1 Pattern 
Gap 41 Length 

Gap #1 Pattern 


Encoding Method #2 
Preamble #2 Length 
Preamble #2 Pattern 
Syne #2 Pattern 
Postamble #2 Length 
Postamble #2 Pattern 
Gap #2 Length 

Gap #2 Pattern 


Parameter 


User defined 
vendor defined 
Vendor defined 
vendor defined 
Device dependent 
Action dependent 
vendor defined 


MSB of # of Bytes 
MedSB of § of Bytes 
LSB of # of Bytes 

MSB of # of Bytes 
MedSB of # of Bytes 
LSB of # of Bytes 

MSB of # of Sec Pulses 
MedSB of # Sec Pulses 
LSB of # of Sec Pulses 
Sectoring Method 


MSB of # of Cylinders 
LSB of ¢ of Cylinders 
Number of Heads 
Number of Heads 


Encoding Method 

§ of Bytes 
Preamble Pattern 
Sync Pattern 

# of Bytes 
Postamble Pattern 
# of Bytes 

Gap Pattern 


Encoding Method 

# of Bytes 
Preamble Pattern 
Syne Pattern 

# of Bytes 
Postamble Pattern 
# of Bytes 

Gap Pattern 


The range of numbers E@ Hex through FF Hex is reserved for unique 


vendor applications. 
future standardization. 


All other unused numbers are 


reserved for 


All unused bits in parameters shall be zero. 


* See section 4.3.8 for validity of this byte 
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4.3 Device Attribute Commands 


These optional commands allow the host to manage the device's mass 
memory configuration, The host can interrogate each device on the 
daisy chain bus to determine each device's attributes. The host 
may then modify the attributes of the devices to optimize 
parameters of the subsystem. Device type, model IDs, etc. are also 
provided. 


The Device Attribute Commands are: Load Attribute Number, Load 
Device Attribute, and Report Device Attribute. They are used to 
load and/or report device attributes but they do not cause any 
operation that effects the characteristics of the device. All 


Device Attribute Commands are optional. 


The Parameter Byte transferred with the Load Attribute Number 
Command is used as an number to select a device attribute. This 
number remains valid for all subsequent Load Device Attribute 
Commands and Report Device Attribute Commands until changed by 
another Load Attribute Number Command. If for a received number no 
attribute is assigned or the function is not implemented in the 
particular device, the Attention Condition and the Illegal Command 
' Bit in the General Status Byte shall be set. 


The Load Device Attribute Command shall set the selected attribute 
to the value transferred with the Parameter Byte. If the selected 
attribute can be read only and not be altered, the Attention 
Condition and the Illegal Command Bit in the General Status Byte 
shall be set. If an illegal value is loaded the Attention 
Condition and the Illegal Parameter Bit in the General Status Byte 


shall be set. 


The Report Device Attribute Command shall cause the selected 
device to return the current value of the selected attribute. The 
Report Device Attribute Command shall work for all implemented 
attributes. , 


4.3.1 User ID (Number @@ Hex) 


This attribute is a user settable and readable byte that can be 
used by the user for any purpose. It is intended to be used to 
identify the characteristics of the device the host is 


communicating with. 


4.3.2 Model ID High (Number @1 Hex) 
This attribute is a read only byte that the device vendor may set 


to any value for any purpose. It is intended to be used to 
identify a particular device model. 
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4.3.3 Model ID Low (Number 62 Hex) 


This attribute is a read only byte that the device vendor may set 
to any value for any purpose, It is intended to be used to 
identify a particular device model. 


4.3.4 Revision ID (Number @3 Hex) 


This attribute is a read only byte that the device vendor may set 
to any value for any purpose. It is intended to be used to 
identify the revision level of a particular device. 


4.3.5 Reserved (Number 94 — 6C Hex) 


These attributes are reserved for future standardization. 


4.3.6 Device Type ID (Number @D Hex) 


This attribute is a read only byte that identifies the device as 
defined below: 


8@ Hex = Not used 

@1 Hex = Non-removable disk 

@2 Hex = Removable disk 

@3 Hex = Combination removable and non-removable disk 


@4-FF Hex = Reserved for future standardization 


4.3.7 Attribute Table Modification (Number @E Hex) 


The purpose of this attribute is to permit an orderly modification 
of the Attribute Table (see Table 4-3). 


When the device goes to Initial State, bit 7 of this attribute is 
set. After or during the Initial State generation the device 
initializes the Attribute Table. When the table is initialized by 
the device bit 7 is reset and bit 6 is set. A host may at its 
option modify any byte and if it does the device must reset bit 6. 
After all bytes have been modified the host sets bit 5. 


When any subsequent byte, except number Hex @E, is modified, bits 
5 and 6 are reset and bit 4 is set. After a host has modified the 
byte(s) it must execute a Load Device Attribute Command with 
number Hex @E selected. This shall reset bit 4 and set bit 5. 
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When either bit 7 or bit 4 is equal to one, the table is partially 
modified and is not safe to use. Bit 5 is set to establish that 
the table values are safe to use. As long as bit 6 remains set the 
table contains the initial values set by the device. 


This attribute is defined as follows: 


Bit 7 = One : The Attribute Table is being modified by the device. 
This bit is set by the device and is reset by the 
device upon completion of the modification process. 


Bit 6 = One : The initial device attribute values have not been 
modified. This bit is set by the device upon 
attaining the Initial State and is reset when any 
Load Device Attribute Command (except to number Hex 
QE) is executed or the Partition Track Command is 
executed. 


Bit 5 


One : This bit, which is set by a host, is used to signify 
that the Attribute Table is complete and ready for 
use. This bit is reset on any Load Device Attribute 
Command except to number §E Hex. This bit can be set 
only by executing a Load Device Attribute Command to 
number @E Hex. 


Bit 4 = One : This bit is set by the device after a Load Device 
Attribute Command is executed after bit 5 was equal 
to a one. This bit can only be reset by executing a 
Load Device Attribute Command to number §E Hex. 


The setting of this bit causes bit 5 of Sense Byte 2 
to be set. 


Bits 9,1,2 and 3 shall be zero. 
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4.3.8 Table ID (Number @F Hex) 
This attribute defines the meaning of numbers 10 = FF Hex. 


When the value of this attribute is equal to @1 Hex, then Sections 
4.3.9 to 4.3.39 define the attributes for numbers 108 - FF Hex. 


When the value of this attribute is equal to FF Hex, see vendor 
Specifications for meaning of numbers 19 - FF Hex. 


When the value of this attribute is equal to @@ Hex, the values of 
all table numbers are undefined, 


All other values of this attribute are reserved for future 
standardization. 


4.3.9 Bytes Per Track High (Number 18 Hex) 


This attribute is the most significant byte of a 24 bit number 
that represents the total number of unformatted bytes that occur 


between active going edges of Index Pulses. 


4.3.18 Bytes Per Track Medium (Number 11 Hex) 


This attribute is the medium significant byte of a 24 bit number 
that represents the total number of unformatted bytes that occur 
between active going edges of Index Pulses. 


4.3.11 Bytes Per Track Low (Number 12 Hex) 


This attribute is the least significant byte of a 24 bit number 
that represents the. total number of unformatted bytes that occur 


between active going. edges of Index Pulses. 


4.3.12 Bytes Per Sector el, (Number 13 Hex) 


This attribute is the most significant byte of a 24 bit Aine 
that represents the total number of bytes that occur between 
active going edges of Sector pulses,.and between the active going 
edge of the Index Pulse and the active going edge of the first 
Sector Pulse. 
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4.3.13 Bytes Per Sector Medium (Number 14 He x) 


This attribute is the medium significant byte of a 24 bit number 
that represents the total number of bytes that occur between 
active going edges of Sector Pulses, and between the active going 
edge of the Index Pulse and the active going edge of the first 
Sector Pulse. 


4.3.14 Bytes Per Sector Low (Number 15 Hex) 


This attribute is the least significant byte of a 24 bit number 
that represents the total number of bytes that occur between 
active going edges of Sector Pulses, and between the active going 
edge of the Index Pulse and the active going edge of the first 


Sector Pulse. 


4.3.15 Sector Pulses Per Track High (Number 16 Hex) 


This attribute defines the most significant byte of a 24 bit 
number that indicates the number of Sector Pulses between but 
excluding Index Pulses generated by hard sectored devices. The 
Sector Pulses are used to divide a track into sectors. The length 
of the sectors (distance between Sector Pulses) is defined by the 


Bytes Per Sector attribute. 


4.3.16 Sector Pulses Per Track Medium (Number 17 Hex) 


This attribute defines the medium Significant byte of a 24 bit 
number that indicates the number of Sector Pulses between but 
excluding Index Pulses generated by hard sectored devices. The 
Sector Pulses are used to divide a track into sectors. The length 
of the sectors (distance between Sector Pulses) is defined by the 
Bytes Per Sector attribute. 
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4.3.17 Sector Pulses Per Track Low (Number 18 Hex) 


This attribute defines the least significant byte of a 24 bit 
number that indicates the number of Sector Pulses between but 
excluding Index Pulses generated by hard sectored devices. The 
Sector Pulses are used to divide a track into sectors. The length 
of the sectors (distance between Sector Pulses). is defined by the 
Bytes Per Sector attribute. 


4.3.18 Sectoring Method (Number 19 Hex) 


This attribute defines the sectoring method used in the device. 
The attribute may allow either loading and reporting if the device 
provides two or more sectoring methods which are selectable by the - 
host or it may allow Reporting only if the device provides only 
one sectoring method. The sectoring methods are defined as 


follows: 


Value Sectoring Method 

@6 Hex Invalid 

81 Hex Hard Sectoring 

@2 Hex Soft-sectoring with DC-erased 
Address Marks 

64 Hex Soft-sectored with Address Marks 
with Missing Clocks 

@8-EF Hex Reserved for future standardization 

FO-FF Hex Unique Vendor Methods 


Note: Combinations of the above Hex codes are valid. 


4.3.19 Number of Cylinders High (Number 28 Hex) 


This attribute is the most significant byte of a 16 bit number 
that represents the number of cylinders implemented in the device. 
This number is one greater than the maximum allowable cylinder 


address that can be addressed, | 
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4.3.20 Number of Cylinders Low (Number 21 Hex) 


This attribute is the least significant byte of a 16 bit number 
that represents the number of cylinders implemented in the device. 
This number is one greater than the maximum allowable cylinder 
address that can be addressed. 


4.3.21 Number of Moving Heads (Number 22 Hex) 

This attribute represents the number of moving heads implemented 
in the device. This number is one greater than the maximum 
allowable moving head address that can be addressed. : 

4.3.22 Number of Fixed Heads (Number 23 Hex) 

This attribute represents the number of fixed heads implemented in 


the device. This number is one greater than the maximum allowable 
fixed head address that can be addressed. 
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Figure 4-1 


Sector Formats for Attributes Hex 38 - 47 


Index/ | | 

Sector _| | | 

Format A |Pre= |Sync| Header|Post-|Gap|Pre- |Sync| Data |Post-|Gapl 
Jamble] | Infor-]amble| jamble] - | Infor-l|amble|] ~:I 
| #1 [| #1 | mation] #1 J#1 1 #2 | #2 | mation] #2 |#2 | 

#1 #2 

Format B |Pre= [Sync] . Information | Post=|Gap] 
Jamble] | (including header and data) | amble|] | 
| #2 | #2 | #2 al 8 1 #2 #2 | 


4.3.24 Header Encoding Method #1 (Number 39 Hex) 


This attribute represents the header encoding method used for all 
fields labeled "#1" in the device and is defined as follows: 


Value Encoding Method 


@6 Hex _— Modified Frequency Modulation (MFM) 
81 Hex ANSI Group Code Recording (GCR) 
@2-EF Hex Reserved for future standardization 
FO-FF Hex’ ; Unique vendor method 


The definition of formatting requirements as defined by Commands 38 - 
47 is based on one of the formats in Figure 4-1. 


4.3.24 Preamble #1 Length (Number 31 Hex) 


This attribute represents the minimum number of .header preamble 
bytes required by the device. ; 
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4.3.25 Preamble #1 Pattern (Number 32 Hex) 


This attribute represents the pattern to be recorded in the header 
preamble bytes. The pattern shall be recorded starting with the 


most significant bit. 


4.3.26 Synchronization $1 Pattern (Number 33 Hex) 
This attribute represents the pattern to be recorded in a one byte 


header synchronization field following the preamble. The pattern 
shall be recorded starting with the most significant bit. 


4.3.27 Postamble #1 Length -_(Number 34 Hex) 


This attribute represents the minimum number of. header postamble 
bytes required-by the device. A value of zero indicates that no 


postamble is required. 


4.3.28 Postamble #1 Pattern (Number 35 Hex) 


This attribute represents the pattern to be recorded in the header 
postamble bytes. The pattern shall be recorded starting with the 


most significant bit. 


4.3.29 Gap #1 Length (Number 36 Hex) 


This attribute represents the minimum number of bytes in the 
header gap (splice area) between postamble and the next preamble. 


4.3.38 Gap #1 Pattern (Number 37 Hex) 


This attribute represents the pattern to be recorded in the header 
gap bytes. The pattern shall be recorded starting with the most 
Significant bit. 
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4.3.31 Data Encoding Method #2 (Number 49 Hex) 


This attribute represents the encoding method used for all fields 
labeled "#2" in the device and is defined as follows: 


Value Encoding Method 


68 Hex Modified Frequency Modulation (MFM) 
G1 Hex ANSI Group Code Recording (GCR) 
@2-EF Hex Reserved for future standardization 
FO-FF Hex . Unique vendor method 


The definition of formatting requirements as defined BY Commands 36 ~ 
47 is based on one of the formats in Figure 4-1. = 


4.3.32 Preamble #2 Length (Number 41 Hex) - 


This attribute represents the minimum number of preamble bytes- - 
required by the device. 


4.3.33 Preamble #2 Pattern (Number 42 Hex) 

This attribute represents the pattern to be recorded in the preamble 
bytes. The pattern shall be recorded starting with the most 
significant bit. 

4.3.34 Synchronization #2 Pattern (Number 43 Hex) 

This attribute represents the pattern to be recorded in a one byte. 


synchronization field following the preamble, The pattern shall be 
recorded starting with the most significant bit. 


4.3.35 Postamble #2 Length (Number 44 Hex) 


This attribute represents the minimum number of postamble bytes 
required by the device. A value of zero indicates that no postamble is 


required. 
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4.3.36 Postamble #2 Pattern (Number 45 Hex) 


This attribute represents the pattern to be recorded in the postamble 
bytes. The pattern shall be recorded starting with the most 
Significant bit. 


4.3.37 Gap #2 Length (Number 46 Hex) 

This attribute represents the minimum number of bytes in the gap 
(splice area ) between postamble and the next preamble. 

4.3.38 Gap #2 Pattern (Number 47 Hex) 


This attribute represents the pattern to be recorded in the gap bytes. 
The pattern stall be recorded starting with the most significant bit. 
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Table 4-4 


General Status Byte 


Bit # Multiport Meaning Mandatory Method of- 
(Common/ /Optional Clearing 
Specific) 

G Cc Not Ready ***-- >. -° M° Self Clearing. 

1 s Control Bus Error * M- Clear Fault Cmd. 

2 s Illegal Command *- ™M Clear Fault Cmd. 

3 S Illegal Parameter * M Clear Fault Cmd. 

4 C/S Sense Byte 1 ** M ee 

5 Cc/S Sense Byte 2 **. M <* 

6 Cs Busy Executing . M Self Clearing 

7 Cc Normal Complete * M Clear Attention 


cmd. 


* A zero to one transition of -this bit shall. set the Attention 
Condition. 


** See Sense Byte 1 and Sense Byte 2. 


**k* The ready to not ready -and not: ‘ready to ready transition shall -set- 
the Attention Condition. . 
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Bit # 


ee 


WHA 


SHO 


a 


Multiport 
(Common/ 
Specific) 


ey ee 


Multiport 
(Common/ 
Speci fic) 


ee oe on ee 


C/s . 


Table 4-5 


Sense Byte 1 


Meaning . 


Ne ak kk a a ee ee oe 


Seek Error * 


Read/Write Fault * 


Power Fault * 


Read/Write Permit * 


Violation 

Speed Error * 
Command Reject * 
Other Errors *.. 


Vendor Unique Errors* 


Table 4-5 


Sense Byte 2 


Meaning 


ek ee ae ek tk a ee te et 


Initial State * 


Ready Transition * 


Device Reserved 
to This Port 


Forced Release ice 


Device Reserved 


to Alternate 
Port 


Device Attribute 
Table Modified * 


- positioned Within 


Write Protected 
Area 


Vendor Unique 
Attentions * 


Mandatory 
/Optional 


16) 
10) 
M 
Oo 
19) 


Mandatory 
/Optional 


eet oe oe ot ee 


Method of 
Clearing 


Clear Fault cmd. 
Clear Fault Cmd. 
Clear Fault cmd. 


Clear Fault Cmd. 
Clear Fault cmd. 
Clear Fault Cmd. 
Clear Fault Cmd.. 
Clear Fault Cmd.--: 


Method of 
Clearing 


Clear Attention 
cmd. 
Clear Attention 
cmd. 


Self Clearing 
Clear Attention 


cmd. 


Self Clearing 


Clear Attention 
cmd. 


Self Clearing 


Clear Attention 
cmd. 


Note: If option is not implemented or undefined its bit value must 


be zero. 


* A zero to one transition of this bit shall set the Attention 
Condition. 
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Table 4-7 


Command Busy/Not Ready Relationships 


Function Busy Signal . Not Ready Busy Executing 
Status . Status 


-_~ 
ke a ee ee a ea a ant ath ee ee he ot a el a th a kh ek ee ah Oe Ee mm a 


No Power 
Spinning Up *-- 
Spinning Down * 
Motor Stopped 
Idle Condition 
Missing Media_. 
Seeking * 
Offsetting *. 
Power Fault *** 
Diagnostic 

R/W Operation 


vouaedvdaaandng 
Qyvanerarerra 
Qrearraa arrag 


* 
* 


* Indicates time dependent operation 
D Indicates device vendor dependent state. 


** WARNING: If a device allows a command transfer during a read or 
write operation data errors may result ~~ 


*** Status is as indicated for non catastrophic power faults. 
Castastrophic power faults result in undefined state for the three 


signals. 


Note: In a multiport device, when the device is explicitly ‘reserved, 
the above table does not apply to alternate Bornes Resultant status 
may be vendor dependent. 
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4.4 Status Reporting 
4.4.1 General Status Byte 


4.4.1.1 Bit @ - Not Ready 


The Not Ready Bit shall be set if the device ‘is unable to perform. 
any head motion or read/write operation. 


Index, Sector/Address Mark Detected, and Read/Reference Clock. are 
invalid when the device is not ready. : 


The Not Ready Bit shall be reset when the device becomes ready. 


The ready to not ready and not ready to ready transition shall set 
the Attention Condition, 


See Table 4-7 for Busy/Not Ready relationship. 


4.4.1.2 Bit 1 -— Control Bus Error 


This bit shall be set if the device detects a protocol or parity 
error during the transfer of a command or parameter such .as: 


- Control Bus Parity error (if implemented) 
—- Command Request and Bus Direction Out inactive 
- The level of the Bus Direction Out Signal” for~- the~ transfer ~ of 


the Parameter Byte does not comply with the Command Code. 
- Two consecutive Parameter cycles 
- Two consecutive Command cycles 


The device shall2not act upon the command transferred during a 
Command/Parameter.-cycle resulting in a Control Bus Error; Ifthe 
Bus Direction Out Signal is inactive for the second byte and a 
Control Bus Error has been detected, the device shall return the 
General Status Byte. 


The Control Bus Error Bit shall be reset by the Clear Fault 
Command. 


The detection of a Control Bus Error shall set the Attention 
Condition. - 
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4.4.1.3 Bit 2 = Illegal Command 


This bit shall be set if the device detects an illegal command 
such as: 


a) The command received is not implemented in the device. — . 

b) The device detected a parity error in the Command Byte which 
shall also set the Control Bus Error Bit. ; 
This error may occur because of a hardware or software error, 
during a self-configuring process or when receiving the "Report 
Illegal Command" Command. . 


The Illegal Command Bit shall be reset by the Clear Fault Command. 


This error shall set the Attention Condition. 


4.4.1.4 Bit 3 ~ Illegal. Parameter ~ 


This bit shall be set if the device tests for -and detects an 
illegal parameter or part of a parameter such as: 


a) The parameter is an address and exceeds the valid range (e.g. 
illegal head address). 
b) Any other illegal parameter value. 

c) The device detected a parity error-in-the Parameter .Byte which. 
shall also set the Bus Error Bit.:: 


The Illegal .Parameter Bit. shall be reset by the Clear Fault 
Command. se 


This error shall set the Attention Condition. 
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4.4.1.5 Bit 4 ~ Sense Byte l 


This bit shall be generated by an "OR" function of all bits in the 
Sense Byte 1 status byte. The Sense Byte 1 Bit shall be reset if 


all bits of the Sense Byte 1 are zero. 


4.4.1.6 Bit 5 ~ Sense Byte 2° 
This bit shall be generated by an “OR" function of all bits in the 


Sense Byte 2 status byte. The Sense Byte 2_Bit shall be reset if 
all bits of the Sense Byte 2 are, zero. 


4.4.1.7 Bit 6 - Busy Executing 


This bit shall be set during the execution of any Time Dependent 
Command. See Tables 4-1 and 4-2. > 


Note: This status bit is different from the Busy ‘interface signal 
(see Section 3.2.7). 


4.4.1.8 Bit 7 —- Normal Complete 


This bit shall: be set if the device has successfully. completed the 
execution of-a Time Dependent Command. See Tables: 4-1 and 4-2. 


The Normal Complete Bit shall be reset by the Clear Attention 
Command. ee re 


The zero to one transition of this bit shall set the Attention 
Condition. 
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4.4.2 Sense Byte 1 
4.4.2.1 Bit @ - Seek Error 


The Seek Error Bit shall be set if a head positioning command. 
(Seek, Rezero, Seek To Landing Zone or. Offset) cannot be completed 


successfully. 


If a Rezero Command is required for recovery, a successful ~rezero 
operation shall reset this bit. If no Rezero Command is required, 
the Clear Fault Command shall reset this bit. 


The zero to-one transition of this bit shall‘ seti ‘then Attention. 
Condition. 


4.4.2.2 Bit 1 = Read/write Fault |... ae 


This bit shall be set-if the device is not able to executé -a “Read 
Command or a Write Command: or. detects’ a: fault during “reading~or: 
writing. Two kinds of faults are distinguished: 


ab Bit 1 and Bit 5 shall be set if the execution of a read/write 
function requested by making Read Gate or Write Gate active is 
prevented by one of the following conditions: 


-Write Gate active “and writing disabled with -a Write. Control 


Command (see Section 4.1.1.2). 
-Write Gate active and heads offset (see Section 4.1.2.5). 


b) Bit 1 only shall be-set if the device detects a fault in_its 
read/write section, for example: 


=Simultaneous selection of more than-one head. 
“Write Gate active but no: write ‘current 
-Optionally the bit may: bé set dfi:the device detects. Read Gate: andes 


Write Gate active simultaneously. 


The Read/wr ite Fault Bit shall be reset by the Clear Fault 
Command. ; 


The zero to one transition of this bit shall set the Attention 
Condition. 


4.4.2.3 Bit 2 ~ Power Fault 


This bit shall be set if the device tests for and detects a 
failure such as overvoltage or undervoltage in one of its supply 
voltages. 


This bit shall be reset by the Clear Fault Command if the power 


failure no longer exists. 
The zero to one transition of this bit shall set the Attention 


Condition. 
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4.4.2.4 Bit 3 ~ Read/Write Permit Violation 


This bit shall be set if writing to the currently accessed track 
is not permitted (see Sections 4.1.2.9 and 4.1.2.19) and Write 
Gate is active. This bit shall be set if reading from the 
currently accessed track is not permitted (see Sections 4.1.2.7 
and 4.1.2.8) and Read Gate is active. . 


This bit shall be reset by the Clear Fault Command. 


The zero to one transition of this bit shall set the Attention 
Condition. ° 


4.4.2.5 Bit 4 ~ Speed Error 


This bit shall be set if “the device tests for and detects that the 
spindle speed is: not -within the -device vendor specified 


tolerances. 


This bit shall be reset by the Clear Fault Command if the spindle 
speed is within the specified tolerance. 


The zero to one transition of this bit shall set the Attention 
Condition. 


4.4.2.6 Bit 5 — Command Reject 


This bit shall be set if the device received a command. which it. 
cannot execute at this time because of some -interlocking condition 


Or command sequence error. 

This status bit -may .be.set in combination with another status bit: 
_that.defines-the reason:why-the°>command was rejected.-:e.g. 7:The. 
device is not ready and has received a: command ‘that:‘cannot be: 
executed (such as, Seek when the disk is not rotating) .~ 

The Command Reject Bit shall be reset by the Clear Fault Command. 


The zero to one transition of this bit shall set the Attention 
Condition. 
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4.4.2.7 Bit 6 = Other Errors 


This bit shall be set if the device detécts an error which is not 
covered by Error Status Bits @ through 5 or 7. 


This bit shall be reset by the Clear Fault Command if the error no 
longer exists. 


The zero to one transition of this bit shall set the Attention 
Condition. 


4.4.2.8 Bit 7 - Vendor Unique Errors 
This bit shall be set as defined by the device vendor. 


This bit shall. be reset. by the Clear Fault: Command if the error no- 
longer exists... 


The zero to one transition of this bit shall set the -Attention 
Condition. 
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4.4.3 Sense Byte 2 


4.4.3.1 Bit @ ~ Initial State 


This bit shall be set if an initialize procedure has been entered 
and the procedure has been completed. : 


The Initialize State’ Bit shall be reset by a Clear Attention 
Command. , 


The zero to one ‘transition ) of this bit ‘shall’ -set .the. Attention . 
Condition. 


4.4.3.2 Bit 1 - Ready Transition 


This bit shall be set if a zero to one or a one to zero transition 
of the Not Ready Bit (see Section 4.4.1.1) -~has occurred. 


The Ready Transition’ Bit shall be reset by a Clear Attention 
Command. 


The zero to one transition of this bit shall set the Attention 
Condition. 
4.4.3.3 Bit 2 ~ Device Reserved to This Port 


This bit is used for multiport devices. It shall be set when the 
device is explicitly reserved to the port requesting Sense Byte 2. 


This bit shall be reset when the device is released. 


‘4.4.3.4 Bit: 3. Forced Release 
If bit 2 of Sense Byte 2 was cleared by a Forced Release (see 
Section 4.2.2.3) then this bit shall be set. (This bit shall. be- 


set if the device previously reserved to the port Eequestsnd Sense. 
Byte 2 has been released due to a Forced Release). 


This bit shall ‘be-reset by a Clear Attention Command. 


The zero to one transition of this bit shall set the Attention 
Condition. 
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4.4.3.5 Bit 4 ~ Device Reserved to Alternate Port 


This bit is used for multiport devices. It shall be set when the 
device is explicitly reserved to a port other than the one 
requesting Sense Byte 2. 


This bit shall be reset when the device is released, - 


4.4.3.6 Bit 5 ~ Device Attribute Table Modified 


This bit shall be set if. bit 4 of the Table Modification Attribute 
Number Hex @E is set to a one (see Section 4.3.7). 


This bit shall be reset by a Clear Attention Command. 

The zero to one transition of this bit shail set the -Attention 
Condition. ; : 

4.4.3.7 Bit 6 ~ Positioned Within Write Protected Area 


This bit shall be set by the device whenever Write Control (see 
Section 4.1.1.2) has placed the device in the write disable state. 


This bit shall be set by the device whenever the head is 
positioned within an area that has been. defined as Write Protected- 
(see Section 4.1.2.15 & 16) and the device is write enabled. 


Any means that write protects an area of the device shall be. 
reflected in this bit. x 


This bit shall be cleared whenever the head(s) is positioned 
outside of the Write Protected area. . 


This bit is not defined during ‘head movement. 


4.4.3.8 Bit 7 ~ Vendor Unique Attentions 
This bit shall be set as. defined by the Vendor. 
This bit shall be reset by a Clear Attention Command. . 


The zero to one transition of this bit shall set the Attention 
Condition. 
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5.9 Timing Specification 


The timing characteristics described in the following paragraphs 
are referenced to the signals at the device interface connector. 
The host timing shall be designed to accommodate cable delays and 


Signal skew within the cable.” — 


Note: This section takes precedence, with respect to actions and 
timing, over all preceding sections. All waveforms in the timing 
diagrams show the voltage levels of the signals. A "=" in front of 
a signal name indicates a "LOW" -active, “HIGH" -inactive signal. 
A "+" in front of a signal name indicates a "HIGH" -active, "LOW" 


-inactive signal. 


5.1 Control Bus Timing— 
5.1.1 Selection Timing ~ 


The active going edge of the Select Out/Attention In Strobe shall 
be used to clock the select information on the dedicated Control 
Bus line into the device. A successful selection shall be 
acknowledged by making Bus Acknowledge active. In the host the 
inactive going edge of the Select Out/Attention In Strobe Signal 
shall be used to sample the Bus. Acknowledge Signal. If Bus 
Acknowledge is not-.active within the specified time, the host 
shall assume that the desired device does not exist or is 
inoperable. The state of the Busy Signal indicates to the host if 
the selected device will accept commands..and _respond, to the 


Control Bus handshake. 


Deselecting all devices shall be accomplished by an active going 
edge of Select. .OUt/Attention In Strobe with none ofthe Control 
Bus lines active, | 


The select timing is defined in Figure 5-1. 


5.1.2 Attention Timing 


In general the timing of the party line Attention Signal (see 
Section 3.2.8) is asynchronous to the Control Bus Signals. 
However, if a command error or parameter error is detected, the 
Attention Condition shall be set and if enabled the Attention 
Signal shall be made active prior to the active going edge of Bus 
Acknowledge which is returned as a response to the Parameter 
Request. All other events (completion or errors) shall make 
Attention active (if enabled) immediately, when they occur. 


Attention shall be made inactive prior to the active going edge of 
the Bus Acknowledge which is returned aS a response to the 
Parameter Request of a Clear Attention Command or Clear Fault 
Command. Attention shall not be made inactive by a Clear Fault 
Command if the error that caused Attention to be made active still 


exists. 
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To determine which one of the attached devices has caused the 
party line Attention Signal to be active, the host polls all 
devices simultaneously by making the Bus Direction Out Signal 
inactive and changing the Select Out/Attention In Strobe from 
inactive to active. Each device shall then immediately gate its 
internal Attention Condition onto its dedicated Control .Bus line. 
Additionally, the selected device, if any, shall make the Bus 
Acknowledge Signal active. : 


The Attention timing is defined in Figure 5-2. 


5.1.3 Control Bus Handshake Timing 


The Control Bus handshake is performed by three interface signals: 
Command Request, Parameter Request, and Bus Acknowledge. 


The Control Bus handshake timing is-defined in Figures 5.3 and 
5.4. 


5.2 Index and Sector Timing 


The timing of the Index Signal and the Sector signal for 
hard-sectored devices is shown in Figure 5-5. There is one and 
only one Index Pulse per revolution. The Sector Pulses are used to 
divide a track into sectors. The-device inhibits the Sector Pulse 
during the Index Pulse such that a Sector Pulse is not transmitted 


at index. 

The Index Signal and Sector Signal are enabled with - device 
selection. The Index Signal and Sector Signals shall not be 
considered valid until at least 598 nanoseconds after the active 
going edge of the Select Out/Attention In Strobe Signal which. 
caused the selection of the device. 


5.3 Reference Clock Timing 


The Reference Clock timing is defined in Figure 5-5. 


5.4 Read Timing 


The read timing is defined in Figure 5-7. 
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5.5 Write Timing 


The write timing is defined in Figure 5-8. The Write Clock shall 
be generated in the host from the Reference Clock. The delay time 
from the Reference Clock to Write Clock is a function of cable 
length and circuit delays. The phase difference between the two 
Signals shall be constant during the complete write operation. The 
Write Data Signal and the Write Clock Signal shall be synchronized 
as defined in Figure 5-8. The Read Data Signal is undefined during 


a write operation. ~ 
5.6 Address Mark Timing (optional) 


The Read Address Mark timing is defined in Figure 5-9. The Write 
Address Mark timing is defined in Figure 5-16. 
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tl 
t2 
t3 
t4 
ts 
t6 
t7 
ts 
t9 
tl 
tl 


Select Out/ 


Figure 5-1 
Select Timin 


Attn.In Strobe 


Bus Ackn. 
Bus Dir.Out 


Control Bus 


Busy 


AA / 


: t 
{t4} J11]t5] 1t6] [t7]t81 


X/// \WA 


LLLTL/  \XX% 
} to | 


Select Information 


| 
}<= t19 =>] 


».4 
Selected device's 


Busy Condition 


* Glitch possible -— due to previously selected device. 


To avoid glitch deselect all devices and then 


select. 


bel Description min. 
Select/Attention Strobe width 506 
Bus Acknowledge invalid — 4] 
Bus Acknowledge. hold time | i) 
Device ~ Control Bus release time 9 
Control Bus -— Data setup time 196 
Control Bus = Data hold time é g 
Host ~ Control Bus release time 1090 
Device = Control Bus access time ] 
Host ~ Control Bus access time 199 

9 Busy invalid ) 

1 Device to Host transition g 
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- Units’: 


nanoseconds 
nanoseconds 
nanoseconds 
nanoseconds 
nanoseconds 
nanoseconds 
nanoseconds 
nanoseconds 
nanoseconds 
nanoseconds 


nanoseconds 
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Label Description a 


Figure 5-2 
Attention Timin 


Select Out/ \ / 
Attn.In Strobe 
| <------- tl ------ >| 
[<-- t2 ==>] - « Jt31 
Bus Ackn. \ <7 
| . 
} t4 | } ts | 
Bus Dir.Out / \ 
- | . | 
1t6]t7! }t8 | }t9] |t1gl 
Control Bus SAAS SSSS \AAAAAAX X/7TTT7/ WAXY 
Attention Information 
} tll | 
Attention \ 
kk 


* Active only if there is a previously selected device, 
inactive if all, devices are deselected. 

** Some devices may have Attention active causing the 
host to perform the Attention timing sequence. 


max. - Units .-. 


an a a a ee 


tl 
t2 
t3 
t4 
t5 
t6 
t7 
8 
t9 
tl1o 
til 


Select/Attention Strobe width - “566 race 

Bus Acknowledge. invalid * - g 399 nanoseconds 
Bus Acknowledge hold time g- 196 * nanoseconds 
Bus Direction Out - setup time 108 --- nanoseconds 
Bus Direction Out = hold time g --- nanoseconds 
Host — Control Bus release time 109 -=- nanoseconds 
Device = Control Bus access time 9 a= nanoseconds 
Attention Information invalid ) 199 nanoseconds 
Attention Information hold time i) --- nanoseconds 
Device ~ Control Bus release time @ 109 nanoseconds 
Host ~ Control Bus access time 108 -—-— nanoseconds 
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nanoseconds 


Figure 5-3 
Command/Parameter Out Sequence 


cmd. Request \ / 


Par.Request NK / 
| | 
} tl [tlJt1}] 2 | t1 | tl [tl | 
Bus Ackn.- \ /f \ / 


| | | | 
| | | ] 
Bus Dir.Out .. \ Te « as 


}t3] }t4| 1esl [t4] Ics | }t6|t7] 
Control Bus //////7 \\\X x/7177 7% X/77/77/ YANN 
Command Param. Out 
} ts | 
1t9 | } t9] 


Busy \ \ 


Label Description ; min. max. Units 

tl Handshake response time 4) 19* milliseconds 
t2 Spacing 6 1g* "milliseconds 
t3 Device — Control Bus release time 6 ._.. 199 nanoseconds 

t4 Control Bus = Data setup time 196 == nanoseconds 

t5 Control Bus — Data hold time 4] arias: nanoseconds 

to Host - Control Bus release time 100 “<< nanoseconds 

t7 Device ~ Control Bus access time 9 ~-- nanoseconds 

ts Host = Control Bus access time 1080 --- nanoseconds 

t9 Busy setup time g* --- nanoseconds 


* This value is valid only if the Busy Signal is not active at 
beginning of sequence ‘ 
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Label Description 


Cmd.Request 


Par.Request 


Bus Ackn. 


Bus Dir.Out 


Control Bus 


Busy 


Figure 574 
Command/Parameter In Sequence 


Jtljt1}] t2 | 


XY / ary ONY eh 


} tl 


oN appt dee eee ke ett x 
l l 
ltS}to] [tel lt71 [tS] 


t 
1t5[ J12]t6] }t71 


L4441/ ~~ \\X®& XSL /. X///11/— \\N 
Command Param.in 


| tle | . 4 


\AAX 


t1g | 


Units 


SS a 


tl 
t2 
t3 
t4 
t5 
t6 
t7 
cB 
t9 
tl 
tl 
tl 


Handshake response time 3 16* milliseconds 
Spacing ) 19* milliseconds 
Bus Direction Out - setup time 140 ats nanoseconds 
Bus Direction Out - hold time 4] --- nanoseconds 
Device =~ Control Bus release time 9 166 nanoseconds» 
Control Bus = Data setup time 108 eet nanoseconds 
Control Bus ~ Data hold time 4] --- nanoseconds 
Host ~ Control Bus release time 163 coat aa nanoseconds 
Device ~ Control Bus access time g --- nanoseconds 

] Host ~ Control Bus access time 168 -~-- nanoseconds 

1 Busy setup time 9 * +-- nanoseconds | 

2 Device to Host transition g --- nanoseconds + 


* This value is valid only if the Busy Signal is 


not active at 


beginning cf sequence 
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Figure 575 
Index/Sector Timing (Hard Sectoring) 


Sector Nr. Po n | g | a 1 | ‘2 


- Index oO ns \ / ~ 


[<== t3--->] tl [<== t3--->] 


= Sector \ / j \ — a / 
} t2 1— | t2 [<--t3---> | t2-1 _ 
Label Description - min. max. ~ Units 
tl Index Pulse width 6.5 --- microseconds 
t2 Sector -Pulse width 9.5 ~a- - microseconds 
t3 Interpulse spacing 8.5 --- << microseconds 
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Figure 5-6 
Reference Clock Timing 


+ Reference Clock / \ / 

I<= t1 =>| “| 

Ares = t2 ----->| 
Label Description min. MAX 
tl Reference Clock active time . 9.4*tp 6.6*tp 
t2 Reference Clock period @.95*tp 1.95*tp 
tp nominal Reference Clock period 


* = Multiply 
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Figure 5-7 
Read Timing 


| | K4------------- tl -----+-------+---- >I <== t2 -->] 
- Read Gate \ / Be 
}<-=- t3 -=>] I<- t5 >| | 
+ Read/Ref. /- Ne Ine be We ~\ TS NT NP Nas 
Clock Ref.clk. invalid : Read Clock se Ref.clk. 
| ==>] t4|]<-- 2 ee | 
| | | 
| . | t6] t7! | 
+ Read Data \ / X X xXx 
Static static 
Label Description —. ae ; min. max. - 
tl Read Gate active : g --- 
t2 Read Gate inactive 2*tp apc 
t3 Read Gate to valid-:Read Data —_ 
and Read .Clock See vendor specifications 
ta Read Clock active time @.4*tp @.6*tp= 
t5 Read Clock period =: 8.95*tp 1.95*tp 
t6 Read Data setup time @.25*tp aes) 2 
t7 Read Data hold time 08.25*tp --- 
tp nominal Reference Clock period 


* = Multiply 
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Figure 5-8 
Write Timing © 


| <------------ tl ------------- >|<-= t2 -=>1- 
- Write \ / Nee 
Gate 
[<= t3 =>] [<= tS >] Sie G | 
+ Write [a ee ae 7 Xe ff ROS JN _ 
Clock static : poo tyne static 
| —>] t4l<- | 
| | t6] t7] | 
+ Write er ray re ee a ee ge ee 
Data static . static 
Label Description. “222.0. .°° 05 min. type c:. maxe 
tl Write Gate active i) ea en 
t2 Write Gate inactive -: 3g Se ae 
t3 Write Clock valid t --- 16*tp 
t4 Write Clock active time 9.4*tp --- g@.6*tp 
ts Write Clock period - ‘=-- tp --- 
t6 Write Data setup time 9.25*tp <--- =a 
t7 Write Data hold time , @.25*tp --- --- 
tp nominal Reference Clock period 


* = Multiply 
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Figure 5-9 


Read Address Mark Timing 


= Read Gate oe ey aa \ oe / 

|} tl | | t2= 4 
—- Address Mark Control os \ / 

| <--= £3 --=>].--44 | 5-1 

= Address Mark Detected \ / 
Label Description min. max. ~ ‘Units 
Sie oe le Ml ca eee te et Ba a Se a ee SN 
tl Read Gate setup.time- ) ---  * nanoseconds 
t2 Read Gate hold time -- B ~-+ +7 nanoseconds 
t3 Address Mark Control setup time. 24*tp --- .. tas 
t4 Address Mark Control hold time a --- nanoseconds 
ts Address Mark Detected hold time ** g 166 nanoseconds 
tp nominal Reference Clock period 


* = Multiply 


** = This hold time applies to the earliest loss of Read Gate or Address 


Mark Control. 
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Figure 5-10 


Write Address Mark Timing 


= Write Gate \ / 
J} tl J<--—= £2 -<=>] t3 | 


- Address Mark Control \ / 

Label Description min. max. Units 

ee eee Ae ee COE ee eee er ETS oe Ee ee Te TSE SERIO RE Re eee AE EO, 
tl Write Gate setup time ) <-- nanoseconds 

£2 Address Mark Control width 24*tp <--- oe ems ae 

t3 Write Gate hold time Las ie 6 --- . nanoseconds 

tp nominal Reference Clock period a 


ts Multiply ~ 
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